美文网首页
Java并发编程之闭锁与栅栏

Java并发编程之闭锁与栅栏

作者: 与李_han | 来源:发表于2020-07-19 21:47 被阅读0次

一、前言

闭锁与栅栏是在多线程编程中的概念,因为在多线程中,我们不能控制线程的执行状态,所以给线程加锁,让其按照我们的想法有秩序的执行。

  • 闭锁

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);

                // 模拟三个任务
        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

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并发编程之闭锁与栅栏

    一、前言 闭锁与栅栏是在多线程编程中的概念,因为在多线程中,我们不能控制线程的执行状态,所以给线程加锁,让其按照我...

  • 同步工具类CyclicBarrier原理及使用

    简介 栅栏类似于闭锁,它能阻塞一组线程直到某个事件的发生。栅栏与闭锁的关键区别在于,所有的线程必须同时到达栅栏位置...

  • java并发编程实战栅栏

    栅栏类似于闭锁,它能阻塞一组线程直到某个事件发生。栅栏与闭锁的关键区别在于,所有线程必须同时到达栅栏位置,才能继续...

  • Java并发编程之CyclicBarrier详解

    简介栅栏类似于闭锁,它能阻塞一组线程直到某个事件的发生。栅栏与闭锁的关键区别在于,所有的线程必须同时到达栅栏位置,...

  • 同步工具类之CyclicBarrier

    一, CyclicBarrier栅栏简介 栅栏(Barrier)类似闭锁,他能阻塞一组线程直到某个事件发生.栅栏与...

  • 闭锁(Latch)实现 CountDownLatch 和 栅栏

    闭锁(Latch)实现 CountDownLatch 和 栅栏 CyclicBarrier 闭锁 CountDow...

  • 闭锁和栅栏

    闭锁:可以延迟线程的进度直到线程到达某个终点状态,只有当某个条件满足的时候,所有线程才可能被并发执行。 栅栏:栅栏...

  • Java并发 闭锁 CountDownLatch

    参考鸿洋大神 的 http://blog.csdn.net/lmj623565791/article/detail...

  • java并发 - CountDownLatch(闭锁)

    CountDownLatch ,juc下的同步工具类,简称闭锁。它允许一条或者多条线程等待其他一条或者多条线程执行...

  • 并发编程之美-终章chat

    一、Java 并发编程之美:并发编程高级篇之五 微信扫码二维码加入本 Chat 作为 Java 并发编程之美系列的...

网友评论

      本文标题:Java并发编程之闭锁与栅栏

      本文链接:https://www.haomeiwen.com/subject/jearkktx.html