初学CyclicBarrier回环栅栏

本文通过实例详细解析了CyclicBarrier的使用方法及应用场景,演示了如何利用CyclicBarrier实现多线程间的同步等待。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我不喜欢讲理论, 直接上代码看效果, 简单''粗暴''!

代码1:

	public static void main(String[] args) throws Exception {
		
		CyclicBarrier cyclicBarrier = new CyclicBarrier(3);
		
		for (int i = 0; i < 3; i++) {
			System.out.println("第"+i+"次循环开始");
			cyclicBarrier.await();
			System.out.println("第"+i+"次循环结束");
		}
	}

首先创建CyclicBarrier对象, 构造传入一个int类型, 这里传入3 , 表示需要有3个线程调用 cyclicBarrier对象的await()方法后,

所有的线程到cyclicBarrier.await()代码后的代码才会继续执行

所以这段代码结果如下:


代码2:

    public static void main(String[] args) throws Exception {

		CyclicBarrier cyclicBarrier = new CyclicBarrier(3);
		
		new Thread() {
			public void run() {
				try {
					System.out.println(Thread.currentThread().getName()+":执行你想要的操作");
					Thread.sleep(5000);
					cyclicBarrier.await();//让当前线程到await状态
				} catch (Exception e) {
					e.printStackTrace();
				}
				System.out.println(Thread.currentThread().getName()+":执行后续操作");
			}
		}.start();
		
		new Thread() {
			public void run() {
				try {
					System.out.println(Thread.currentThread().getName()+":执行你想要的操作");
					Thread.sleep(7000);
					cyclicBarrier.await();//让当前线程到await状态
				} catch (Exception e) {
					e.printStackTrace();
				}
				System.out.println(Thread.currentThread().getName()+":执行后续操作");
			}
		}.start();

		for (int i = 0; i < 3; i++) {
			System.out.println("第" + i + "次循环开始");
			cyclicBarrier.await();//让当前线程到await状态
			System.out.println("第" + i + "次循环结束");
		}
    }

创建了2个线程, 并且让每个线程都到await状态, (为了看到效果,可以让线程睡眠一下),结果:

可以看到, 当有3个线程调用了 cyclicBarrier.await(), 后第1次循环就执行完,  

但是第2次循环, 又停住了,   因为CyclicBarrier 对象是循环使用的,  即: 回环

所以又要有3个线程执行: cyclicBarrier.await();  则第2次循环才回执行完


我们抽取创建线程的代码,

代码3:

	public static void main(String[] args) throws Exception {

		CyclicBarrier cyclicBarrier = new CyclicBarrier(3);

		for (int i = 0; i < 3; i++) {
			System.out.println("第" + i + "次循环开始");

			if (i == 0 || i == 1) {
				// 创建2个线程, 执行cyclicBarrier.await();
				createTwoThreadExcuteAwait(cyclicBarrier);
			}

			cyclicBarrier.await();// 让当前线程到await状态
			System.out.println("第" + i + "次循环结束");
		}

	}

	private static void createTwoThreadExcuteAwait(CyclicBarrier cyclicBarrier) {
		new Thread() {
			public void run() {
				try {
					System.out.println(Thread.currentThread().getName() + ":执行你想要的操作");
					Thread.sleep(5000);
					cyclicBarrier.await();// 让当前线程到await状态
				} catch (Exception e) {
					e.printStackTrace();
				}
				System.out.println(Thread.currentThread().getName() + ":执行后续操作");
			}
		}.start();

		new Thread() {
			public void run() {
				try {
					System.out.println(Thread.currentThread().getName() + ":执行你想要的操作");
					Thread.sleep(7000);
					cyclicBarrier.await();// 让当前线程到await状态
				} catch (Exception e) {
					e.printStackTrace();
				}
				System.out.println(Thread.currentThread().getName() + ":执行后续操作");
			}
		}.start();

	}

结果如下, 你应该也可猜到: 第3次循环只开始,没有结束(这里打印的是i的值, i从0开始,所以为"第2次循环") 

到现在, 应该明白这个CyclicBarrier,这个回环栅栏的简单使用吧


应用场景:(个人想法)

比如用户上传大文件, 后台将一个大文件分成很多小文件, 多线程往很多数据库存数据,   当所有数据库都写完了, 

才能往主数据库记录文件信息和上传状态等

,然后才能返回给用户,上传成功!

等等!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值