java 并发协作控制
1. Lock
可实现同步的效果;tryLock()可判断是否空闲。
ReentrantLock类:可重入锁。
ReentrantReadWriteLock类:可重入读写锁,允许多个读,一个写。
lock(), unlock()方法。
2. Semaphore
信号量,是一个计数器,可以设置一定个数的并发量。
方法:acquire()获取;
release()释放。
限定多少个信号量同时访问关键区域。
3. Latch
等待锁,是一个同步辅助类,用来同步多个任务。
CountDownLatch类。
方法:countDown(): 计数减1
await(): 等待Latch为0,开始向下执行。
4. Barrier
集合点,为同步辅助类,多个线程在同一点进行同步。
CyclicBarrier类。
方法:await(): 等待其他线程,达到数量后放行。
5. Phaser
同步辅助类,允许多阶段多任务运行。
Phaser类
方法: arrive():可以不等待;
arriveAndAwaitAdvance(), 需要等待。
6. Exchanger
允许并发过程中,两个线程互换消息。
在各自的线程中定义同步点,当二者执行到特定位置时,互换消息。
方法exchange()。(对方给的为null时,丢弃)。