闭锁(CountDownlatch)
主要用到countDown()方法与await()方法
每到CountDown就使计数器减一,await会等到计数器==0的时候,解锁
栅栏(CyclicBarrier)
cyclicbarrier ccb=new cyclicbarrier(num);
主要方法是await方法,每个有栅栏的线程都会在执行到await处停住,
直到有num个数量的持有await的线程执行到await。
这些线程才会越过栅栏继续往前运行
CountDownLatch的计数器只能使用一次,
而CyclicBarrier的计数器可以使用reset()方法重置,
可以使用多次,所以CyclicBarrier能够处理更为复杂的场景;
CountDownLatch : 一个线程(或者多个), 等待另外N个线程完成某个事情之后才能执行。 CyclicBarrier : N个线程相互等待,任何一个线程完成之前,所有的线程都必须等待。
这样应该就清楚一点了,对于CountDownLatch来说,重点是那个“一个线程”, 是它在等待, 而另外那N的线程在把“某个事情”做完之后可以继续等待,可以终止。而对于CyclicBarrier来说,重点是那N个线程,他们之间任何一个没有完成,所有的线程都必须等待。
CountDownLatch 是计数器, 线程完成一个就记一个, 就像 报数一样, 只不过是递减的.
而CyclicBarrier更像一个水闸, 线程执行就想水流, 在水闸处都会堵住, 等到水满(线程到齐)了, 才开始泄流.
信号量(Semaphore)
semaphore s=new semaphore(2);
Acquire 加锁 ,release 释放
信号量里最多两个线程,当有一个线程被释放的时候才可以进入新的线程。
Tryacquire 尝试获得通行证,如果得到了就是true,得不到就是false。
vlolatile
用于保证共享变量的可见性,但是在有原子性操作的时候无法保证。