Java并发编程之闭锁与栅栏的实现
一、前言
闭锁与栅栏是在多线程编程中的概念,因为在多线程中,我们不能控制线程的执行状态,所以给线程加锁,让其按照我们的想法有秩序的执行。
闭锁
CountDownLatch,实例化时需要传入一个int类型的数字(count),意为等待count个线程完成之后才能执行下一步动作。
如今天要做的事情是吃晚饭,再去散步。假设11个人相约晚饭后一起去散步,我们得等11个人全都吃完晚饭了才能出发去散步。简而言之就是做了才到达某一种状态。
栅栏
CyclicBarrier,实例化时需要传入一个int类型的数字(parties),意为等待parties个线程都准备就绪后才能执行自己的任务。
如今天要做的事情是吃晚饭,8个人约好一起去某餐厅吃饭,得等到人齐了才能去吃饭。简而言之就是到达某种状态后一起做。
二、实例
闭锁 CountDownLatch
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | 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 ); // 模拟三个任务 List<String> jobs = new ArrayList<String>(); 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
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | 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 ); // 模拟创建三个任务 List<String> jobs = new ArrayList<String>(); 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方法后,才能继续执行自己内部的方法。
到此这篇关于Java并发编程之闭锁与栅栏的实现的文章就介绍到这了,更多相关Java 闭锁与栅栏内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
- Java并发编程volatile关键字的作用
- java并发编程专题(十一)----(JUC原子类)数组类型详解
- java并发编程专题(十)----(JUC原子类)基本类型详解
- java并发编程专题(九)----(JUC)浅析CyclicBarrier
- java并发编程专题(八)----(JUC)实例讲解CountDownLatch
- java并发编程专题(七)----(JUC)ReadWriteLock的用法
- java并发编程专题(六)----浅析(JUC)Semaphore
- java并发编程专题(五)----详解(JUC)ReentrantLock
- java并发编程专题(四)----浅谈(JUC)Lock锁
- java并发编程专题(三)----详解线程的同步
- java并发编程专题(二)----如何创建并运行java线程
- java并发编程专题(一)----线程基础知识
- Java并发编程示例(一):线程的创建和执行
- Java并发编程示例(六):等待线程执行终止
- Java 并发编程的可见性、有序性和原子性
微信公众号搜索 “ 脚本之家 ” ,选择关注
程序猿的那些事、送书等活动等着你
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!
相关文章
使用IDEA搭建Hadoop开发环境的操作步骤(Window10为例)
经过三次重装,查阅无数资料后成功完成hadoop在win10上实现伪分布式集群,以及IDEA开发环境的搭建。一步一步跟着本文操作可以避免无数天坑2021-07-07解决Eclipse/STS中出现Resource is out of sync with the file system
今天小编就为大家分享一篇关于解决Eclipse/STS中出现Resource is out of sync with the file system的异常问题,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2018-12-12
最新评论