学习java juc 之aqs 简单总结
二零一九 年 九月二十一日
1.CountDownLatch
同步辅助类,可以阻塞线程
awiat(); 使调用当前方法的线程处于阻塞状态,直到countDown();方法把计数器变为 0之后解除锁定。计数器不可以被重置。
使用场景:程序执行需要等待某个条件完成后才能继续执行,例如并行计算。
面试问题:假如一个任务在指定时间内完成如果没有完成就跳过?
可以用await(时间,单位)方法实现。
2. Semaphore
信号量 acquire(个数),拿到许可 release(个数)释放许可 主要对并发数做控制 tryAcquire()尝试获取一个执行 如果获取则执行,否则放弃
使用场景:仅能提供有限访问的资源 比如数据库连接最大20,然而访问数远远大于20,可以用Semaphore来做控制。
3.CyclicBarrier (比 CountDownLatch更加强大)
允许一组线程相互等待,直到到达一个公共的屏障点 循环屏障
使用场景 :多线程计算数据,然后合并计算结果。
awiat()
实现多个线程相互等待,直到到达一个条件。
new 该对象时可以在第二个new Runnable 优先执行 Runnable
4.ReentrantLock 与 锁
lock(); unlock();
可重入锁
cas算法
三大特性:
可指定是公平锁还是非公平锁
提供了一个Condition类
提供能够中断等待锁的线程的机制lock.lockInterruptibly()