信号量和条件之间的区别(ReentrantLock)

MI8*_*I89 2 java concurrency semaphore locking

有谁知道这些方法之间的差异acquire ()release ()(java.util.concurrent.Semaphore)和await ()signal (new ReentrantLock().newCondition() ).

你能为这些方法公开一个伪代码吗?

Jan*_*cek 11

从表面上看,这些方法的行为可能看起来很相似 - acquire()/await() 可以使release()/signal()线程在某些情况下阻塞,并且在某些情况下可以解除阻塞线程.但是,信号量和条件有不同的用途:

  • java.util.concurrent.Semaphore是一种相对较高级别的同步机制,供一般开发人员使用.您通常会使用它来限制对某些资源的并发访问acquire(),方法是在访问资源之前调用每个请求者线程(如果没有可用的信号量许可,那么就会产生线程阻塞).来自javadoc的描述:

    从概念上讲,信号量保持一组许可.如果需要,每个acquire()都会阻止,直到有许可证可用,然后接受它.每个release()都会添加一个许可证,可能会释放一个阻塞收单器.

  • java.util.concurrent.locks.Condition是一种相对低级的同步机制,它基本上增强了功能提供的java.lang.Object方法wait(),notify()并且notifyAll().它允许线程在需要等待某些条件变为真时(通常通过其他线程的活动)暂停其活动,然后它使那些其他线程在状态变量采取时"唤醒"等待的线程条件中的部分可能已经改变.通常更难正确使用,建议一般开发人员使用java.util.concurrent包中的更高级别的机制(如Semaphore).

您可以在Brian Goetz的优秀书籍"Java Concurrency in Practice"中找到有关此内容的更多详细信息.