首页 > 其他分享 >ArrayBlockingQueue简单介绍

ArrayBlockingQueue简单介绍

时间:2022-11-09 22:36:37浏览次数:40  
标签:org 简单 boot 介绍 import ArrayBlockingQueue new public blockingQueue

ArrayBlockingQueue是一个用数组实现的环形队列,在构造方法中,会要求传入数组的容量

创建数组长度为10的有界队列,数据类型为字符串
BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(10);

  

 

 

 

<?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>


    </dependencies>


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


</project>

  

server.port=2001


logging.level.com.java.test=debug
logging.level.web=debug
spring.devtools.add-properties=false

  

package com.java.test;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * @Description:
 * @Author: Yourheart
 * @Create: 2022/10/20 15:32
 */
@SpringBootApplication
public class TestApplication {
    public static void main(String[] args) {
        SpringApplication.run(TestApplication.class,args);
    }
}

 创建线程池,调用位置

package com.java.test.blockingqueuedemo;

import com.google.common.util.concurrent.ThreadFactoryBuilder;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.concurrent.*;

/**
 * @Description:
 * @Author: Yourheart
 * @Create: 2022/11/7 14:22
 */
@Slf4j
@RestController
public class ArrayBlockingQueueDemo {

    BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(10);


    ThreadFactory namedThreadFactory = new ThreadFactoryBuilder()
            .setNameFormat("demo-pool-%d").build();


    ExecutorService singleThreadPool = new ThreadPoolExecutor(2, 10,
            0L, TimeUnit.MILLISECONDS,
            new ArrayBlockingQueue<>(10), namedThreadFactory, new ThreadPoolExecutor.AbortPolicy());


    /**
     * 启动线程放置数据
     * @return
     */
    @GetMapping("/blockingQueueTest")
    public String blockingQueueTest() {

        singleThreadPool.execute(new ArrayBlockingQueueThread(blockingQueue));

        return blockingQueue.poll();

    }

    /**
     * 启动线程取出数据
     * @return
     */
    @GetMapping("/blockingQueueGet")
    public String blockingQueueGet(long threadSleepTime) {
        singleThreadPool.execute(new ArrayBlockingQueueGet(blockingQueue,threadSleepTime));
        blockingQueue.forEach(a->{
            log.info("队列中的数据:{}",a.toString());
        });
        return blockingQueue.poll();
    }

    @GetMapping("/blockingQueueQuery")
    public String blockingQueueQuery(long threadSleepTime) {
        singleThreadPool.execute(new ArrayBlockingQueueGet(blockingQueue,threadSleepTime));
        blockingQueue.forEach(a->{
            log.info("队列中的数据:{}",a.toString());
        });
        return blockingQueue.poll();
    }
}

  

http://127.0.0.1:2001/blockingQueueTest

http://127.0.0.1:2001/blockingQueueGet?threadSleepTime=500

http://127.0.0.1:2001/blockingQueueQuery?threadSleepTime=500

  

package com.java.test.blockingqueuedemo;

import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang.StringUtils;

import java.util.concurrent.BlockingQueue;

/**
 * @Description:
 * @Author: Yourheart
 * @Create: 2022/11/7 17:04
 */
@Slf4j
public class ArrayBlockingQueueGet implements Runnable {

    private BlockingQueue<String> blockingQueue;

    private long threadSleepTime;


    public ArrayBlockingQueueGet(BlockingQueue<String> blockingQueue, long threadSleepTime) {
        this.blockingQueue = blockingQueue;
        this.threadSleepTime = threadSleepTime;
    }

    @Override
    public void run() {
        while(true){
            synchronized (this){
                try {
                    String poll = blockingQueue.poll();
                    if (StringUtils.isBlank(poll)){
                        continue;
                    }
                    log.info("poll:{}",poll);
                    //将此处的睡眠时间分别改为100和1000,观察运行结果
                    Thread.sleep(threadSleepTime);
                    blockingQueue.take();
                    log.info("队列中剩余数据个数:{}",blockingQueue.size());
                    blockingQueue.forEach(a->{
                        log.info("【队列中剩余的数据】:{}",a.toString());
                    });
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

  

package com.java.test.blockingqueuedemo;

import lombok.extern.slf4j.Slf4j;

import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.concurrent.BlockingQueue;

/**
 * @Description:
 * @Author: Yourheart
 * @Create: 2022/11/7 16:52
 */
@Slf4j
public class ArrayBlockingQueueThread implements Runnable {

    BlockingQueue<String> blockingQueue;

    public ArrayBlockingQueueThread(BlockingQueue<String> blockingQueue) {
        this.blockingQueue = blockingQueue;
    }

    @Override
    public void run() {
        while (true){
            try {
                Thread.sleep(500);
               // String toString = UUID.randomUUID().toString();
                Date date = new Date();
                SimpleDateFormat simpleDateFormat=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
                String format = simpleDateFormat.format(date);
                blockingQueue.put(format);
                log.info("线程:{},放置的数据:{},当前队列中的数据个数:{}",Thread.currentThread().getName(),format,blockingQueue.size());
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

 

 

  

 

 

 

 

标签:org,简单,boot,介绍,import,ArrayBlockingQueue,new,public,blockingQueue
From: https://www.cnblogs.com/q202105271618/p/16864646.html

相关文章

  • Nginx分发算法介绍
    分发算法:如何将用户请求按照一定的规律分发给业务服务器。主要分为Nginx集群默认算法和基于请求头分发算法。nginx的upstream目前支持4种方式的分配:1)轮询(默认)  每......
  • Nginx集群介绍
    一、Nginx集群组成组成要素:1)VIP:给分发器的一个虚IP2)分发器:nginx3)数据服务器:web服务器二、nginx集群原理在Nginx集群中Nginx扮演的角色是分发器。主要任务是接受请求......
  • ElasticJob‐Lite:作业分片策略介绍与源码分析
    分片弹性调度是​​ElasticJob​​​最重要的功能,也是这款产品名称的由来。它是一款能够让任务通过分片进行水平扩展的任务处理系统。​​ElasticJob​​​中任务分片项的......
  • HDU 1237 简单计算器
    ProblemDescription读入一个只包含+,-,*,/的非负整数计算表达式,计算该表达式的值。Input测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字......
  • Redis:哈希表HLEN、HSTRLEN、HINCRBY、HINCRBYFLOAT、HSCAN命令介绍
    HLENHLENkey时间复杂度:O(1)返回哈希表​​key​​中域的数量。演示当哈希表​​key​​不存在时,返回0。HSTRLENHSTRLENkeyfield可用版本:>=3.2.0时间复杂度:O(1)返回哈希......
  • HTML----介绍
    HTML开发工具:vscode推荐书籍:HTML+css入门到精通1.HTML介绍超文本标记语言:浏览器只能看懂HTML、css、js,所以web开发中HTML是最基本的一门语言,普通的文本扩展上音频、视......
  • 1 consul介绍
    consul介绍用于实现分布式系统的服务发现与配置。与其它分布式服务注册与发现的方案,Consul的方案更“一站式”,内置了服务注册与发现框架、分布一致性协议实现、健康检......
  • 颠覆传统BOM检查!用这个方法既​简单、快速又准确
    BOM(BillofMaterial)物料清单是物料采购和产品生产的重要参考,其准确性直接影响产品的质量,把BOM的问题研究明白,那么这个项目就基本完成了一大半。在很多大公司都会开发专门......
  • 1 zookeeper介绍
     https://mirror.bit.edu.cn/apache/zookeeper/https://www.cnblogs.com/sakura-yxf/p/12020348.html 1Zookeeper集群的角色:Leader和follower(Observer) 只要集群......
  • WCF的简单实例(手写代码实现)--服务端
    1、引用:usingSystem.ServiceModel;usingSystem.ServiceModel.Description;2、申明接口///这是接口[ServiceContract(Namespace="http://Microsoft.ServiceModel.Sampl......