java中的CyclicBarrier的问题

古月椒 2016-05-10 09:14:48
package cn.itcast;

import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class CyclicBarrierTest {
public static void main(String[] args) {
ExecutorService service = Executors.newCachedThreadPool();
final CyclicBarrier cb = new CyclicBarrier(3);

for (int i = 0; i < 3; i++) {
Runnable runnable = new Runnable() {
public void run() {
try {
Thread.sleep((long) Math.random() * 10000);
System.out.println("线程" + Thread.currentThread().getName() +
"即将到达集合地点1,当前已有"+ (cb.getNumberWaiting() + 1) + "个已经到达,"
+ (cb.getNumberWaiting() == 2 ? "都到齐了,继续走啊" : "继续等待"));
cb.await();
} catch (InterruptedException e) {
e.printStackTrace();
} catch (BrokenBarrierException e) {
e.printStackTrace();
}
}
};

service.execute(runnable);
}
service.shutdown();
}
}
上述代码执行过程中,getNumberWaiting()方法不能正确打印出正在等待的线程数。。很奇怪,这里也不需要什么同步的问题吧,运行了好多次。。还求大神赐教。。
...全文
79 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
家里敷泥呀 2016-05-10
  • 打赏
  • 举报
回复
Thread.sleep((long) (Math.random() * 10000)); 这里少了一个括号。
古月椒 2016-05-10
  • 打赏
  • 举报
回复
这是其中一次的运行结果,按道理,输出的数据应该是1 2 3.。。。。实在不懂啊。。求大神 线程pool-1-thread-1即将到达集合地点1,当前已有1个已经到达,继续等待 线程pool-1-thread-2即将到达集合地点1,当前已有1个已经到达,继续等待 线程pool-1-thread-3即将到达集合地点1,当前已有2个已经到达,继续等待

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧