Java并发编程--CountDownLatch配合线程池

Java并发编程–CountDownLatch配合线程池

在处理一些耗时操作的时候,我们习惯上会把它放在子线程里面做,是的如果允许(我是指操作的内容),为了更快速地完成这堆操作,线程池是一个不错的选择。等等,好像有点不对,如果需要等待所有的线程在执行完后触发一个操作,这个时候你就需要用到CountDownLatch。

其实这涉及到多线程异步转同步的问题,在java 1.5中,提供了一些非常有用的辅助类来帮助我们进行并发编程,比如CountDownLatch,CyclicBarrier和Semaphore,但是如果需要配合线程池使用,CountDownLatch是不错的选择(Semaphore还没用过。。。所以没选它)。

这里先下个结论:

  1. CountDownLatch和CyclicBarrier都能够实现线程之间的等待,只不过它们侧重点不同;
  2. CountDownLatch一般用于某个线程A等待若干个其他线程执行完任务之后,它才执行;
  3. 而CyclicBarrier一般用于一组线程互相等待至某个状态,然后这一组线程再同时执行;
  4. 另外,CountDownLatch是不能够重用的,而CyclicBarrier是可以重用的。

先看看CountDownLatch提供的方法:
Java并发编程--CountDownLatch配合线程池_第1张图片

CountDownLatch只有一个构造方法:

public CountDownLatch(int count) {  };  //参数count为计数值

然后下面这3个方法是CountDownLatch类中最重要的方法:

//调用await()方法的线程会被挂起,它会等待直到count值为0才继续执行
public void await() throws InterruptedException { };   

//和await()类似,只不过等待一定的时间后count值还没变为0的话就会继续执行
public boolean await(long timeout, TimeUnit unit) throws InterruptedException { };  

//将count值减1
public void countDown() { };  

在看看CyclicBarrier的方法:

public CyclicBarrier(int parties, Runnable barrierAction) {
}

public CyclicBarrier(int parties) {
}

public int await() throws InterruptedException, BrokenBarrierException { };
public int await(long timeout, TimeUnit unit)throws InterruptedException,BrokenBarrierException,TimeoutException { };

看完后你会发现CountDownLatch和CyclicBarrier两者的await方法是会阻塞当前线程的,因此如果在线程池中使用CyclicBarrier,如果线程池的core大小小于parties,线程池中的线程遍一直处于阻塞状态,相反CountDownLatch的countDown()在执行后,完美退出当前线程,但是在开启调用CountDownLatch.await()的时候,需要在子线程中,否则就阻塞了当前线程。

参考链接:http://www.cnblogs.com/dolphin0520/p/3920397.html

你可能感兴趣的:(Java并发编程)