Java并发编程之闭锁与栅栏
2021-04-13 12:29
标签:rgs 类型 new int 创建 import ati run方法 模拟 闭锁与栅栏是在多线程编程中的概念,因为在多线程中,我们不能控制线程的执行状态,所以给线程加锁,让其按照我们的想法有秩序的执行。 CountDownLatch,实例化时需要传入一个int类型的数字(count),意为等待count个线程完成之后才能执行下一步动作。 如今天要做的事情是吃晚饭,再去散步。假设11个人相约晚饭后一起去散步,我们得等11个人全都吃完晚饭了才能出发去散步。简而言之就是做了才到达某一种状态。 CyclicBarrier,实例化时需要传入一个int类型的数字(parties),意为等待parties个线程都准备就绪后才能执行自己的任务。 如今天要做的事情是吃晚饭,8个人约好一起去某餐厅吃饭,得等到人齐了才能去吃饭。简而言之就是到达某种状态后一起做。 执行结果: Thread-1 : 进入run方法 Thread-2 : 进入run方法 Thread-2 : 执行third Thread-0 : 进入run方法 Thread-1 : 执行second Thread-0 : 执行first 回到main线程 通过执行结果可看出,当所有线程都执行完后才能回到主线程继续执行后面的输出。 执行结果: Thread-1 : 进入run方法 Thread-2 : 进入run方法 Thread-0 : 进入run方法 Thread-0 : 执行first Thread-1 : 执行second Thread-2 : 执行third 通过执行结果可看出,当所有线程都执行都进入到run方法后,才能继续执行自己内部的方法。 Java并发编程之闭锁与栅栏 标签:rgs 类型 new int 创建 import ati run方法 模拟 原文地址:https://www.cnblogs.com/yl-space/p/13341416.html一、前言
二、实例
闭锁?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);
// 模拟三个任务
List
栅栏?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);
// 模拟创建三个任务
List