首页 > 其他分享 >Phaser的简单使用

Phaser的简单使用

时间:2023-01-07 23:00:10浏览次数:48  
标签:Phaser 简单 boot springframework phaser 使用 println org

Phaser属于jdk1.7新增的同步工具类

 使用CountDownLatch,主线程执行的任务要等副线程执行完毕才可执行

Phaser达到同等的效果

 

 

package com.java.test.phaser;

import org.junit.Test;

import java.util.Random;
import java.util.concurrent.Phaser;

/**
 * @Description:
 * @Author: Yourheart
 * @Create: 2023/1/4 23:45
 */
public class PhaserTest {

    @Test
    public void test(){

        Phaser phaser = new Phaser(5);

        for (int i = 0; i < 5; i++) {
            new Thread("线程-" + (i + 1)) {
                private final Random random = new Random();
                @Override
                public void run() {
                    System.out.println(getName() + " - 开始运行");
                    try {
                        Thread.sleep(random.nextInt(1000));
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println(getName() + " - 运行结束");
                    phaser.arrive();
                }
            }.start();
        }
        System.out.println("线程启动完毕");
        phaser.awaitAdvance(phaser.getPhase());
        //用Phaser替代CyclicBarrier考虑前面讲CyclicBarrier时,10个工程师去公司应聘的例子,也可以用Phaser实现,代码基本类似。
        System.out.println("线程运行结束");


    }
}

  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>
View Code

实现一起去食堂吃饭,吃饭完在一起去上课

 

 

 

 

 单纯的使用测试注解,会没法执行完成,使用了定时任务实现

package com.java.test.phaser;

import java.util.Random;
import java.util.concurrent.Phaser;

/**
 * @Description
 * @Author qiuxie
 * @Date 2023/1/5 22:08
 */
public class PhaserThread extends Thread{

    private final Phaser phaser;
    private final Random random = new Random();

    public PhaserThread(String name, Phaser phaser) {
        super(name);
        this.phaser = phaser;
    }


    @Override
    public void run() {
        System.out.println(getName() + " - 起床");
        slowly();
        System.out.println(getName() + " - 洗漱完毕");
        // 到达同步点,等待其他线程
        phaser.arriveAndAwaitAdvance();

        System.out.println(getName() + " - 食堂打完菜开始吃饭");
        slowly();
        System.out.println(getName() + " - 吃饭结束");
        // 到达同步点,等待其他线程
        phaser.arriveAndAwaitAdvance();

        System.out.println(getName() + " - 准备出发去教室");
        slowly();
        System.out.println(getName() + " - 全部到达教室");
    }

    private void slowly() {
        try {
            Thread.sleep(random.nextInt(6000));
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

  

package com.java.test.phaser;

import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.Async;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.Scheduled;

import java.util.concurrent.Phaser;

/**
 * @Description
 * @Author qiuxie
 * @Date 2023/1/5 22:08
 */
@Configuration      //1.主要用于标记配置类,兼备Component的效果。
@EnableScheduling   // 2.开启定时任务
public class PhaserThreadTest {

    /**
     * 当天的17点31分0秒执行
     */
    @Scheduled(cron = "0 31 17 * * *")
    @Async
    public void test(){

        Phaser phaser = new Phaser(5);
        for (int i = 0; i <5 ; i++) {
            new PhaserThread("线程-"+(i+1),phaser).start();
        }
        phaser.awaitAdvance(phaser.getPhase());

    }
}

 特性1 动态调整线程个数

 

 

 

 

 

 特性2 层次

 

 一个大的任务细分为很多个小任务,最后将完成的结果汇总

state变量解析

Phaser没有基于AQS实现,但是具备AQS的核心特性

 

 

 

 

 

 阻塞和唤醒

 

 

 

 

 

 

 

标签:Phaser,简单,boot,springframework,phaser,使用,println,org
From: https://www.cnblogs.com/q202105271618/p/17026350.html

相关文章

  • 一文掌握Spring事务的基本使用
    1依赖Spring事务的实际源码在spring-tx中:<dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId></dependency>在Spring体......
  • CMake简单教程
    title:CMake学习date:2023-01-07T20:29:55Zlastmod:2023-01-07T22:33:31ZCMake学习主要就是学习如何写CMakeList.txt,直接从项目实战项目结构common:制......
  • powershell简单的使用gui
    powershell作为win的官方shell,可以调用.net对象。让它可以无所不能。例如给脚本加上图形界面更直观。而且这是win占用文件体积最小的图形程序。几行文本就能构建一个gui程......
  • gdb的使用教程以及gdbpwndbg 常用命令
    gdb的使用教程以及gdb/pwndbg常用命令1、基本使用(参考)#include<iostream>usingnamespacestd;intfunc(intn){ intsum=0; for(inti=0;i<n;i++){ sum+=i;......
  • gdb的使用教程以及gdbpwndbg 常用命令
    gdb的使用教程以及gdb/pwndbg常用命令1、基本使用(参考)#include<iostream>usingnamespacestd;intfunc(intn){intsum=0;for(inti=0;i<n;i++){......
  • 使用云桌面搭建少儿编程环境
    公司从事scratch少儿编程培训,学员需要使用到运行scratch的编程环境。每个培训点大概需要10个左右的电脑。如果使用PC搭建,投入较高,并且管理起来比较复杂。学员再使用后,可能......
  • .Net Core 商城微服务项目系列(十二):使用k8s部署商城服务
    原文网址:https://www.bbsmax.com/A/Ae5RRDeN5Q/一、简介本篇我们将会把商城的服务部署到k8s中,同时变化的还有以下两个地方:1.不再使用Consul做服务的注册和发现,转而使用k......
  • JavaScript学习笔记—使用字面量创建数组
    语法:[]//元素为数字vararr=[1,2,3,6,10];//元素可以是任意数据类型vararr2=["hello",1,true,null,undefined];//也可以是对象varobj={name:"孙悟空......
  • Docker学习使用01
    安装官网地址:https://docs.docker.com/engine/install/centos/1.卸载旧版本yumremovedocker\docker-client\docker-client-......
  • 使用感受
    三丰云免费服务器连接速度快,可以用来测试,使用起来方便、快速,不卡顿,三丰云服务器是全,国免费服务器服务商之一,所提供的免费服务器不仅速度一流,而且使用便捷,三丰云的免费产品非......