最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
Java并发编程之闭锁与栅栏如何实现 Java并发编程之闭锁与栅栏实现代码
时间:2020-04-30 编辑:袖梨 来源:一聚教程网
Java并发编程之闭锁与栅栏如何实现?本篇文章小编给大家分享一下Java并发编程之闭锁与栅栏实现代码,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
一、前言
闭锁与栅栏是在多线程编程中的概念,因为在多线程中,我们不能控制线程的执行状态,所以给线程加锁,让其按照我们的想法有秩序的执行。
闭锁
CountDownLatch,实例化时需要传入一个int类型的数字(count),意为等待count个线程完成之后才能执行下一步动作。
如今天要做的事情是吃晚饭,再去散步。假设11个人相约晚饭后一起去散步,我们得等11个人全都吃完晚饭了才能出发去散步。简而言之就是做了才到达某一种状态。
栅栏
CyclicBarrier,实例化时需要传入一个int类型的数字(parties),意为等待parties个线程都准备就绪后才能执行自己的任务。
如今天要做的事情是吃晚饭,8个人约好一起去某餐厅吃饭,得等到人齐了才能去吃饭。简而言之就是到达某种状态后一起做。
二、实例
闭锁CountDownLatch
package com.test; import java.util.ArrayList; import java.util.List; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CountDownLatch; public class Test { public static void main(String[] args) { CountDownLatch latch = new CountDownLatch(3); // 模拟三个任务 Listjobs = new ArrayList (); jobs.add("first"); jobs.add("second"); jobs.add("third"); // 循环执行任务 for (String job : jobs) { new Thread(new Runnable() { @Override public void run() { System.out.println(Thread.currentThread().getName() + " : 进入run方法"); latch.countDown(); System.out.println(Thread.currentThread().getName() + " : 执行" + job); } }).start(); } try { latch.await(); } catch (InterruptedException e) { e.printStackTrace(); } // 任务都执行完后才执行 System.out.println("回到main线程"); } }
执行结果:
Thread-1 : 进入run方法
Thread-2 : 进入run方法
Thread-2 : 执行third
Thread-0 : 进入run方法
Thread-1 : 执行second
Thread-0 : 执行first
回到main线程
通过执行结果可看出,当所有线程都执行完后才能回到主线程继续执行后面的输出。
栅栏CyclicBarrier
package com.test; import java.util.ArrayList; import java.util.List; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; public class Test { public static void main(String[] args) { CyclicBarrier barrier = new CyclicBarrier(3); // 模拟创建三个任务 Listjobs = new ArrayList (); jobs.add("first"); jobs.add("second"); jobs.add("third"); //循环执行任务 for (String job : jobs) { new Thread(new Runnable() { @Override public void run() { System.out.println(Thread.currentThread().getName() + " : 进入run方法"); try { // 等待 barrier.await(); } catch (InterruptedException | BrokenBarrierException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName() + " : 执行" + job); } }).start(); } } }
执行结果:
Thread-1 : 进入run方法
Thread-2 : 进入run方法
Thread-0 : 进入run方法
Thread-0 : 执行first
Thread-1 : 执行second
Thread-2 : 执行third
通过执行结果可看出,当所有线程都执行都进入到run方法后,才能继续执行自己内部的方法。
相关文章
- SpringBoot自定义bean绑定解析 10-24
- Javaweb工程运行报错HTTP Status 404解决教程 10-20
- JAVA获取jvm和操作系统相关信息方法 10-20
- BeanFactory和FactoryBean的区别讲解 10-20
- 微信小程序的宿主环境实现教程 10-10
- dispatchEvent解决重叠元素响应事件教程 10-10