信号量与条件(ReentrantLock)之间的区别
有谁知道方法acquire ()
和release ()
( java.util.concurrent.Semaphore
)和await ()
和signal (new ReentrantLock().newCondition() )
之间的区别。
你能为这些方法公开一个伪代码吗?
从表面上看,这些方法的行为可能看起来类似 – acquire()/await()
可以使线程在某些情况下阻塞,而release()/signal()
可以在某些情况下解除阻塞。 但是,信号量和条件有不同的用途:
-
java.util.concurrent.Semaphore
是相对较高级别的同步机制,供一般开发人员使用。 您通常会使用它来限制对某些资源的并发访问,方法是在访问资源之前让每个请求者线程调用acquire()
(如果没有可用的信号量许可,那么就会产生线程阻塞)。 来自javadoc的描述:从概念上讲,信号量保持一组许可。 如果需要,每个acquire()都会阻止,直到有许可证可用,然后接受它。 每个版本()都会添加许可证,可能会释放阻塞收单器。
-
java.util.concurrent.locks.Condition
是相对低级的同步机制,它基本上增强了java.lang.Object
方法提供的functionwait()
,notify()
和notifyAll()
。 它允许线程在需要等待某些条件变为真时(通常通过其他线程的活动)暂停其活动,然后它使那些其他线程在状态变量采取时“唤醒”等待的线程条件中的部分可能已经改变。 它通常更难正确使用,建议一般开发人员使用java.util.concurrent包中的更高级别的机制(如Semaphore)。
您可以在Brian Goetz的优秀书籍“Java Concurrency in Practice”中找到有关此内容的更多详细信息。
- Eclipse- Dynamic Web Module 3.0在创建新项目时需要Java 1.6或更高版本的错误
- 经典错误:无法更新中心| http://repo1.maven.org/maven2的索引
- 如何使用Scanner java重复读取用户输入
- Lucene爬虫(它需要构建lucene索引)
- 什么是来自.net的java等效的AggregateException?
- spring – 从类的静态字段中的属性文件中读取属性值
- Java内存模型:创建最终实例字段的循环参考图是否安全,所有这些都在同一个线程中分配?
- `public static void main args’是什么意思?
- Java连接池实现