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

java多线程编程——同步器CyclicBarrier(2)

2012-12-28 
java多线程编程——同步器CyclicBarrier(二)在实际应用中,有时候需要多个线程同时工作以完成同一件事情,而且

java多线程编程——同步器CyclicBarrier(二)
在实际应用中,有时候需要多个线程同时工作以完成同一件事情,而且在完成过程中,往往会等待其他线程都完成某一阶段后再执行,等所有线程都到达某一个阶段后再统一执行。

比如有几个旅行团需要途经深圳、广州、韶关、长沙最后到达武汉。旅行团中有自驾游的,有徒步的,有乘坐旅游大巴的;这些旅行团同时出发,并且每到一个目的地,都要等待其他旅行团到达此地后再同时出发,直到都到达终点站武汉。

这时候CyclicBarrier就可以派上用场。CyclicBarrier最重要的属性就是参与者个数,另外最要方法是await()。当所有线程都调用了await()后,就表示这些线程都可以继续执行,否则就会等待。



16:46:28: SelfTour Reached Shenzhen
16:46:28: BusTour Reached Shenzhen
16:46:31: WalkTour Reached Shenzhen
我们都到了
16:46:34: SelfTour Reached Guangzhou
16:46:35: BusTour Reached Guangzhou
16:46:39: WalkTour Reached Guangzhou
我们都到了
16:46:43: SelfTour Reached Shaoguan
16:46:45: BusTour Reached Shaoguan
16:46:54: WalkTour Reached Shaoguan
我们都到了




上面这段代码也是网上copy的,Barrier的主要作用就是让所有运行Tour的线程执行到有barrier.await();代码的地方等待,当所有的线程都到达这个地点时,就运行runner线程里的代码。所以上面的例子如果运行起来的话,所有线程会在三个地点集体等待,在等待时,执行runner。

热点排行