信号量(Semaphore)
信号量(Semaphore):信号量可以用来控制同时访问某个特定资源的线程数量,或者同时执行某个指定操作的数量(例:可比作是控制流量的红绿灯,比如XX马路要限制流量,只允许同时有一百辆车在这条路上行使,其他的都必须在路口等待,所以前一百辆车会看到绿灯,可以开进这条马路,后面的车会看到红灯,不能驶入XX马路,但是如果前一百辆中有五辆车已经离开了XX马路,那么后面就允许有5辆车驶入马路,这个例子里说的车就是线程,驶入马路就表示线程在执行,离开马路就表示线程执行完成,看见红灯就表示线程被阻塞,不能执行 *)。
Semaphore中管理着一组虚拟的许可(permit),许可的数量可通过构造方法来提定,在执行操作进先通过acquire方法获得许可(只要还有剩余的许可),并在使用后释放。如果没有许可,那么acquire方法将阻塞该线程直到有许可(或被中断或操作超时)。release方法可释放一个许可。
(JCIP5-14加上注释和main()):
/** * BoundedHashSet Using Semaphore to bound a collection * * @author Brian Goetz and Tim Peierls * @author Modified by alchimie */ public class BoundedHashSet<T> { private final Set<T> set; private final Semaphore sem; public BoundedHashSet(int bound) { this.set = Collections.synchronizedSet(new HashSet<T>()); // 设置许可数 sem = new Semaphore(bound); } // 获得一个许可并添加一个元素到集合中,如果失败则释放一个许可 public boolean add(T o) throws InterruptedException { sem.acquire(); boolean wasAdded = false; try { wasAdded = set.add(o); return wasAdded; } finally { if (!wasAdded) sem.release(); } } // 从集合中移除一个指定元素,如果成功就释放一个许可 public boolean remove(Object o) { boolean wasRemoved = set.remove(o); if (wasRemoved) sem.release(); return wasRemoved; } public void list() { for (T t : set) { System.out.println(t); } } public static void main(String args[]) throws InterruptedException { final BoundedHashSet<String> bhs = new BoundedHashSet<String>(3); new Thread(new Runnable() { public void run() { try { System.out.println(Thread.currentThread().getName() + "执行开始"); bhs.add("a"); bhs.add("b"); bhs.add("c"); System.out.println(Thread.currentThread().getName() + "执行完成"); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }).start(); new Thread(new Runnable() { public void run() { try { System.out.println(Thread.currentThread().getName() + "执行开始"); bhs.add("d"); System.out.println(Thread.currentThread().getName() + "执行完成"); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }).start(); bhs.list(); bhs.remove("c"); Thread.sleep(500); bhs.list(); } }
执行结果:
Thread-0执行开始
Thread-0执行完成
Thread-1执行开始
b
c
a
Thread-1执行完成
d
b
a
可以看到Thread-0将许可消耗完后,Thread-1将被阻塞,直到bhs.remove("c")执行后释放了一个许可才继续执行。
* 参考http://ifeve.com/tag/semaphore/
相关推荐
3. **并发控制**:Java提供了多种并发控制工具,包括synchronized、wait()、notify()、notifyAll()、ReentrantLock(可重入锁)、Semaphore(信号量)和CountDownLatch(倒计时器)等。这些工具用于协调不同线程的...
《Java并发编程实战》这本书是关于Java语言中并发编程技术的经典著作。它详细介绍了如何在Java环境中有效地实现多线程程序和并发控制机制。在Java平台上,由于其本身提供了强大的并发编程支持,因此,掌握并发编程...
《Java并发编程实战》是一本深入探讨Java平台并发编程的权威指南。这本书旨在帮助开发者理解和掌握在Java环境中创建高效、可扩展且可靠的多线程应用程序的关键技术和实践。它涵盖了从基本概念到高级主题的广泛内容,...
这本书的读书笔记涵盖了多个关键知识点,旨在帮助读者深入理解Java并发编程的核心概念。 1. **线程和进程的区别** - **线程** 是程序执行的最小单位,一个进程中可以有多个线程同时执行,共享同一块内存空间,通信...
《Java并发编程实战》是一本深入探讨Java平台并发编程的权威指南,由Tim Peierls等人与Brian Goetz合著,旨在帮助Java开发者理解和掌握在多线程环境中编写高效、安全的代码。这本书由拥有丰富经验的JDK并发大师及...
《Java 并发编程实战》是一本专注于Java并发编程的权威指南,对于任何希望深入了解Java多线程和并发控制机制的开发者来说,都是不可或缺的参考资料。这本书深入浅出地介绍了如何在Java环境中有效地管理和控制并发...
3. **并发工具类**:Java并发包(java.util.concurrent)包含了许多工具类,如Semaphore(信号量)、CyclicBarrier(回环屏障)、CountDownLatch(计数器门锁)和ThreadPoolExecutor(线程池)。这些工具可以帮助...
62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java...
7. Java内置锁和锁的粒度:Java中的`synchronized`关键字用于实现内置锁,它保证了线程对共享资源的互斥访问。关于锁的粒度,需要根据实际情况来决定是使用细粒度还是粗粒度的锁。使用同步时,需要考虑代码同步块的...
Java并发编程实战需要了解Java中的线程模型、锁机制、线程池、并发集合类等概念和技术,以及如何使用Java中的各种并发编程工具和框架来实现高效、可靠的并发编程。 Java并发编程实战的目标是提高程序的响应速度、...
3. **并发工具类**:如Semaphore(信号量)、CountDownLatch(计数器)、CyclicBarrier(回环栅栏)和Exchanger(交换器)等,这些都是Java并发库提供的重要工具,用于实现复杂的同步和协作机制。 4. **并发集合**...
2. **同步控制**:Java中的`synchronized`关键字用于控制对共享资源的访问,它可以修饰方法或代码块,确保同一时间只有一个线程能执行特定的代码。此外,`ReentrantLock`类提供了更细粒度的锁控制。 3. **并发容器*...
《Java 并发编程实战》是一本面向Java开发者的深度技术书籍,专注于讲解在多线程环境下如何有效地编写高效、安全的并发代码。这本书高清且带有详细的目录,方便读者快速定位到所需的主题,是Java并发编程领域的重要...
除了提供读者全面指南编写并发Java应用程序的书籍“Java Concurrency in Practice”外,还可以下载相关源代码。这包括书中使用的所有源代码示例,可以使用Maven轻松地将其导入Eclipse或IntelliJ IDEA中。通过实践源...
这本"Java并发编程学习笔记"可能是作者在深入研究Java并发特性、工具和最佳实践过程中积累的心得体会。下面,我们将根据这个主题,探讨一些关键的Java并发编程知识点。 1. **线程与进程**:在多任务环境中,线程是...
读书笔记:Java并发编程之美笔记
Java 并发编程实战PDF