think in java笔记:java.util.concurrent.Semaphore
WHAT’S
Semaphore是一个计数锁,很像Linux的Limit. 这个一般会结合资源一起使用,本身是包含了synchronization的,但是不能保证资源的取和释放与acquire()
/release()
是同步的。 所以还是需要在get和release Item的时候,加上同步操作。
接受一个参数或者两个参数:
- Semaphore(int permits): permits可以被多少线程同时访问
- Semaphore(int permits, boolean fair): fair设置为true可以保证线程获取limit的次序和他们调用acquire()的顺序相同,保证FIFO。
需要注意两点:
- 不能和semaphore本身的加锁和释放一起加锁,否则就会出现semaphore无法解锁的情况。
- 在释放Item的时候,先释放Item再释放锁。否则就可能在释放Item之前另外的线程就已经去同步方法中获取Item,就会失败。