A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

public class CyclicBarrierTest {

    public static void main(String[] args) {
        ExecutorService service = Executors.newCachedThreadPool();
        final CyclicBarrier cb = new CyclicBarrier(5);
        for(int i = 0; i < 5; i++) {
            Runnable runnable = new Runnable() {
                @Override
                public void run() {
                    try {
                        Thread.sleep(3 * 1000);
                                                           //为什么cb.getNumberWaiting()方法得到等待的线程的数据不正确呢????
                        System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点1,当前已有" + (cb.getNumberWaiting() + 1) + "已经到达," + (cb.getNumberWaiting() == 4 ? "都到齐了,继续走吧" : "正在等待"));
                        cb.await();
                        
                        Thread.sleep(3 * 1000);
                        System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点2,当前已有" + (cb.getNumberWaiting() + 1) + "已经到达," + (cb.getNumberWaiting() == 4 ? "都到齐了,继续走吧" : "正在等待"));
                        cb.await();
                        
                        Thread.sleep(3 * 1000);
                        System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点3,当前已有" + (cb.getNumberWaiting() + 1) + "已经到达," + (cb.getNumberWaiting() == 4 ? "都到齐了,继续走吧" : "正在等待"));
                        cb.await();
                        
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            };
            service.execute(runnable);
        }
        service.shutdown();
    }

}


打印结果:
线程pool-1-thread-4即将到达集合地点1,当前已有1已经到达,正在等待
线程pool-1-thread-5即将到达集合地点1,当前已有2已经到达,正在等待
线程pool-1-thread-1即将到达集合地点1,当前已有3已经到达,正在等待
线程pool-1-thread-3即将到达集合地点1,当前已有1已经到达,正在等待
线程pool-1-thread-2即将到达集合地点1,当前已有1已经到达,正在等待
线程pool-1-thread-2即将到达集合地点2,当前已有1已经到达,正在等待
线程pool-1-thread-3即将到达集合地点2,当前已有2已经到达,正在等待
线程pool-1-thread-4即将到达集合地点2,当前已有3已经到达,正在等待
线程pool-1-thread-5即将到达集合地点2,当前已有4已经到达,正在等待
线程pool-1-thread-1即将到达集合地点2,当前已有5已经到达,都到齐了,继续走吧
线程pool-1-thread-2即将到达集合地点3,当前已有1已经到达,正在等待
线程pool-1-thread-5即将到达集合地点3,当前已有1已经到达,正在等待
线程pool-1-thread-4即将到达集合地点3,当前已有1已经到达,正在等待
线程pool-1-thread-1即将到达集合地点3,当前已有1已经到达,正在等待
线程pool-1-thread-3即将到达集合地点3,当前已有4已经到达,都到齐了,继续走吧


我把run方法改为public synchronized void run() 则正确了,为什么???这种做法正确吗?

评分

参与人数 1技术分 +1 收起 理由
zzkang0206 + 1

查看全部评分

2 个回复

倒序浏览
程序没错,,,不过我感觉synchronized不能加,加也没用,,,,他们各自操作各自的run方法,我感觉这样写比较好
  1. package aaaa;

  2. import java.util.Random;
  3. import java.util.concurrent.CyclicBarrier;
  4. import java.util.concurrent.ExecutorService;
  5. import java.util.concurrent.Executors;

  6. public class CyclicBarrierTest {

  7.     public static void main(String[] args) {
  8.         ExecutorService service = Executors.newCachedThreadPool();
  9.         final CyclicBarrier cb = new CyclicBarrier(5);
  10.         for(int i = 0; i < 5; i++) {
  11.             Runnable runnable = new Runnable() {
  12.                 @Override
  13.                 public  void run() {
  14.                     try {
  15.                         Thread.sleep(new Random().nextInt(1000));
  16.                                                            //为什么cb.getNumberWaiting()方法得到等待的线程的数据不正确呢????
  17.                         System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点1,当前已有" + (cb.getNumberWaiting() ) + "已经到达," + (cb.getNumberWaiting() == 4 ? "都到齐了,继续走吧" : "正在等待"));
  18.                         cb.await();
  19.                         
  20.                         Thread.sleep(new Random().nextInt(1000));
  21.                         System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点2,当前已有" + (cb.getNumberWaiting() ) + "已经到达," + (cb.getNumberWaiting() == 4 ? "都到齐了,继续走吧" : "正在等待"));
  22.                         cb.await();
  23.                         
  24.                         Thread.sleep(new Random().nextInt(1000));
  25.                         System.out.println("线程" + Thread.currentThread().getName() + "即将到达集合地点3,当前已有" + (cb.getNumberWaiting() ) + "已经到达," + (cb.getNumberWaiting() == 4 ? "都到齐了,继续走吧" : "正在等待"));
  26.                         cb.await();
  27.                         
  28.                     } catch (Exception e) {
  29.                         e.printStackTrace();
  30.                     }
  31.                 }
  32.                
  33.             };
  34.             service.execute(runnable);
  35.         }
  36.         service.shutdown();
  37.     }

  38. }
复制代码

屡试不爽

a.png (10.2 KB, 下载次数: 7)

a.png

评分

参与人数 1技术分 +1 收起 理由
zzkang0206 + 1

查看全部评分

回复 使用道具 举报
王竞 来自手机 中级黑马 2014-4-3 22:45:26
藤椅
哦,这样啊,谢谢
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马