首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 其他相关 >

JAVA 多线程同步工具种总结

2012-12-16 
JAVA 多线程同步工具类总结这两天看了《JAVA 并发编程实战》一书,内容很不错,关于同步常用的几个工具类总结

JAVA 多线程同步工具类总结

这两天看了《JAVA 并发编程实战》一书,内容很不错,关于同步常用的几个工具类总结如下:

CountDownLatch 闭锁:可以延迟线程的进度,直到锁到达终止状态。闭锁的作用相当于一扇门,在锁到达终止状态之前这扇门一直是关闭的。当锁到达终止状态时,允许所有线程通过。CountDownLatch 有一个初始值,通过调用 countDown 可以减少该值,一直到 0 时到达终止状态。

FutureTask 用于执行一个可返回结果的长任务,任务在单独的线程中执行,其他线程可以用 get 方法取任务结果,如果任务尚未完成,线程在 get 上阻塞。

Semaphore 用于控制同时访问某资源,或同时执行某操作的线程数目。信号量有一个初始值即可以分配的信号量总数目。线程任务开始前先调用 acquire 取得信号量,任务结束后调用 release 释放信号量。在 acquire 是如果没有可用信号量,线程将阻塞在 acquire 上,直到其他线程释放一个信号量。

CyclicBarrier 栅栏用于多个线程多次迭代时进行同步,在一轮任务中,任何线程完成任务后都在 barrier 上等待,直到所有其他线程也完成任务,然后一起释放,同时进入下一轮迭代。

CountDownLatch 的例子:

import java.util.concurrent.BrokenBarrierException;import java.util.concurrent.CyclicBarrier;public class DemoOfBarrier {public static void main(String[] args) {final int numOfThread = 2;final int numOfIteration = 2;// 创建一个用于线程同步的 Barrier 对象final CyclicBarrier barrier = new CyclicBarrier(numOfThread,new Runnable() {// 当所有线程到达 Barrier 后会执行这个任务// 任务在第一个 到达 Barrier 的线程中执行@Overridepublic void run() {long tid = Thread.currentThread().getId();// 当所有线程完成一轮迭代之后做点清除/准备/提交工作System.out.printf("[%d] - All threads arrived barrier...%n", tid);try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}System.out.printf("[%d] - Clear work done...%n", tid);}});// 创建并启动多个线程,他们在 Barrier 上同步for (int i = 0; i < numOfThread; i++) {Thread thread = new Thread(new Runnable() {@Overridepublic void run() {long tid = Thread.currentThread().getId();for ( int k=0; k<numOfIteration; k++ ) {try {// 线程进行一轮迭代,做点事情System.out.printf("Thread %d start its work...%n", tid);long duration = (int)(Math.random()*5000);Thread.sleep(duration);// 做完迭代后等待其他线程完成迭代System.out.printf("Thread %d wait on barrier...%n", tid);int num = barrier.await();// 显示完成的顺序System.out.printf("Thread %d pass barrier with order=%d...%n", tid, num);} catch (InterruptedException e) {e.printStackTrace();Thread.currentThread().interrupt();} catch (BrokenBarrierException e) {e.printStackTrace();}}}});thread.start();}}}

热点排行