首页 > 其他分享 >CyclicBarrier简单使用

CyclicBarrier简单使用

时间:2023-01-03 21:56:29浏览次数:35  
标签:Thread spring 简单 boot commons 使用 org CyclicBarrier

CyclicBarrier就是要实现有福同享有难同当的原理,吃饭的时候,要等室友都到了才会一起去吃食堂,吃饭食堂一起去教室

 

 

 

 

 每一阶段完成后,才会开始下一阶段

代码部分

package com.java.test.cyclicbarrier;

import lombok.extern.slf4j.Slf4j;

import java.util.Random;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;

/**
 * @Description:
 * @Author: Yourheart
 * @Create: 2023/1/3 17:57
 */
@Slf4j
public class MyThread extends Thread {
    private final CyclicBarrier barrier;
    private final Random random = new Random();

    public MyThread(String name, CyclicBarrier barrier) {
        super(name);
        this.barrier = barrier;
    }

    @Override
    public void run() {
        try {
            log.info(Thread.currentThread().getName() + " - 起床");
            Thread.sleep(random.nextInt(6000));
            log.info(Thread.currentThread().getName() + " - 洗漱完毕");
            //等待其他的室友
            barrier.await();


            log.info(Thread.currentThread().getName() + " - 食堂打完菜开始吃饭");
            Thread.sleep(random.nextInt(6000));
            log.info(Thread.currentThread().getName() + " - 吃饭结束");
            //等待其他还是吃饭的室友
            barrier.await();

            log.info(Thread.currentThread().getName() + " - 准备出发去教室");
            Thread.sleep(random.nextInt(6000));
            log.info(Thread.currentThread().getName() + " - 全部到达教室");
        } catch (InterruptedException e) {
            e.printStackTrace();
        } catch (BrokenBarrierException e) {
            e.printStackTrace();
        }
    }
}

  

package com.java.test.cyclicbarrier;

import java.util.concurrent.CyclicBarrier;

/**
 * @Description:
 * @Author: Yourheart
 * @Create: 2023/1/3 17:56
 */
public class MainTest {
    public static void main(String[] args) {
        CyclicBarrier cyclicBarrier=new CyclicBarrier(5, new Runnable() {
            @Override
            public void run() {
                System.out.println("该阶段结束...");
            }
        });
        for (int i=0;i<5;i++){
            new MyThread("同学-" + (i + 1), cyclicBarrier).start();
        }
    }
}

  pom文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.java</groupId>
    <artifactId>test-study</artifactId>
    <version>1.0-SNAPSHOT</version>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.1.RELEASE</version>
        <relativePath/>
    </parent>

    <dependencies>
        <!--tomcat容器-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <!--lombok依赖-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.16</version>
        </dependency>
        <!--引入junit单元测试依赖-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
        <!--判断空的用法  -->
        <dependency>
            <groupId>commons-lang</groupId>
            <artifactId>commons-lang</artifactId>
            <version>2.6</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/com.oracle.database.jdbc/ojdbc8 -->
        <dependency>
            <groupId>com.oracle.database.jdbc</groupId>
            <artifactId>ojdbc8</artifactId>
            <version>12.2.0.1</version>
        </dependency>
        <!--springboot整合mybatis-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.1.2</version>
        </dependency>

        <!--添加fastjson依赖-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.70</version>
        </dependency>
        <!-- 热部署模块 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <optional>true</optional> <!-- 这个需要为 true 热部署才有效 -->
        </dependency>
        <!--ThreadFactoryBuilder的依赖包,多线程使用-->
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>30.1-jre</version>
        </dependency>

        <!--Lists.partition要用的依赖-->
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>21.0</version>
        </dependency>
       <!--ListUtils.partition使用的依赖-->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-collections4</artifactId>
            <version>4.4</version>
        </dependency>
        <!--操作redis的依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.9</version>
        </dependency>


    </dependencies>


    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
        <finalName>study</finalName>
    </build>


</project>

  

 

 

 

 

 

 

 

 

 

 

 相对于CountDownLatch,CyclicBarrier可以重复使用。

 

标签:Thread,spring,简单,boot,commons,使用,org,CyclicBarrier
From: https://www.cnblogs.com/q202105271618/p/16999325.html

相关文章

  • ReentrantLock可重入锁的使用场景及API的使用场景
    摘要从使用场景的角度出发来介绍对ReentrantLock的使用,相对来说容易理解一些。场景1:如果发现该操作已经在执行中则不再执行(有状态执行)a、用在定时任务时,如果任务执行时间可......
  • nginx-clojure 调试简单试用
    对于nginx-clojure的调试实际上就是基于jdwp参考配置nginx.confjvm_options"-agentlib:jdwp=transport=dt_socket,address=*:909#{pno},server=y,suspend=......
  • 关于Unreal使用Dedicate Server时的一些研究
    下面的博客链接内容如下:直接点击即可他说的UE4自带的服务器只能用于Development和debugment需要留意一下,不能用于商用版本,说这个性能很低,这个需要我留意一下 这是论......
  • WGCLOUD基础知识整理与学习:数据开放接口使用
    WGCLOUD服务器监测平台,有一批数据开放接口API,可以提供我们使用,用来接入我们自己的业务系统通过这些数据接口,我们可以获取到服务器主机的性能监测数据,然后将这些数据加工处理......
  • 使用YAKINDU STATECHART TOOLS的TypeScript代码生成
    https://blogs.itemis.com/en/typescript-code-generation-with-yakindu-statechart-tools作者DennisvanderVlugt现代web应用越来越复杂,模型驱动开发有助于应对复杂性......
  • 使用SIPp进行压力测试
    本文更新于2022-05-14,使用SIPpv3.5.3。官网:http://sipp.sourceforge.net/。中文文档:http://sipp.sourceforge.net/doc/cn-reference.pdf。安装其它版本请于官网下载。......
  • [MySQL] 索引的使用、SQL语句优化策略
    目录索引什么是索引索引的创建与删除创建索引删除索引索引的使用使用explain分析SQL语句最佳左前缀索引覆盖避免对索引列进行额外运算SQL语句优化小表驱动大表索引什么是......
  • 博客使用框架(js)公示
    博客使用框架公示......
  • fn_dblog()和fn_full_dblog()的使用
    SQLServer2017中,函数fn_full_dblog()对函数fn_dblog()做了改进,允许用户读取事务日志中的活跃部分,检索对数据库修改活动的相关信息。使用fn_dblog()要记住以下几点:1.只......
  • 阿里巴巴 FastJson 使用入门
    1.首先依赖 版本的话一般1.2.58以上都可以<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.58</version></de......