返回顶部
首页 > 资讯 > 精选 >Java基于quasar如何实现协程池
  • 709
分享到

Java基于quasar如何实现协程池

2023-07-02 13:07:35 709人浏览 安东尼
摘要

这篇文章主要介绍了Java基于quasar如何实现协程池,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。业务场景:golang与swoole都拥抱了协程,在同任务并发数量下,协程可比线程多几倍。所以最近在查询java时了解

这篇文章主要介绍了Java基于quasar如何实现协程池,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。

Java基于quasar如何实现协程池

业务场景:golang与swoole都拥抱了协程,在同任务并发数量下,协程可比线程多几倍。所以最近在查询java时了解java本身是没有协程的,但是某牛自行实现了协程,也就是本文的主角quasar(纤程)!不过没看到谁公开一下手写协程池的骚操作(谁会直接new它用?那是没挨过社会的毒打呀~)

一个线程可以多个协程,一个进程也可以单独拥有多个协程。

线程进程都是同步机制,而协程则是异步。

协程能保留上一次调用时的状态,每次过程重入时,就相当于进入上一次调用的状态。

线程是抢占式,而协程是非抢占式的,所以需要用户自己释放使用权来切换到其他协程,因此同一时间其实只有一个协程拥有运行权,相当于单线程的能力。

协程并不是取代线程, 而且抽象于线程之上, 线程是被分割的CPU资源, 协程是组织好的代码流程, 协程需要线程来承载运行, 线程是协程的资源, 但协程不会直接使用线程, 协程直接利用的是执行器(Interceptor), 执行器可以关联任意线程或线程池, 可以使当前线程, UI线程, 或新建新程.。

线程是协程的资源。协程通过Interceptor来间接使用线程这个资源。

Java基于quasar如何实现协程池

废话不多说,直接上代码:

导入包:

        <dependency>            <groupId>co.paralleluniverse</groupId>            <artifactId>quasar-core</artifactId>            <version>0.7.9</version>            <classifier>jdk8</classifier>        </dependency>
WorkTools工具类:
package com.example.ai;import co.paralleluniverse.fibers.Fiber;import co.paralleluniverse.fibers.SuspendExecution;import co.paralleluniverse.strands.SuspendableRunnable;import java.util.concurrent.ArrayBlockingQueue;public class WorkTools {    //协程池中默认协程的个数为5    private static int WORK_NUM = 5;    //队列默认任务为100    private static int TASK_COUNT = 100;    //工做协程数组    private Fiber[] workThreads;    //等待队列    private final ArrayBlockingQueue<SuspendableRunnable> taskQueue;    //用户在构造这个协程池时,但愿启动的协程数    private final int workerNum;    //构造方法:建立具备默认协程个数的协程池    public WorkTools() {        this(WORK_NUM,TASK_COUNT);    }    //建立协程池,workNum为协程池中工做协程的个数    public WorkTools(int workerNum, int taskCount) {        if (workerNum <= 0) {            workerNum = WORK_NUM;        }        if (taskCount <= 0) {            taskCount = TASK_COUNT;        }        this.workerNum = workerNum;        taskQueue = new ArrayBlockingQueue(taskCount);        workThreads = new Fiber[workerNum];        for (int i = 0; i < workerNum; i++) {            int finalI = i;            workThreads[i] = new Fiber<>(new SuspendableRunnable() {                @Override                public void run() throws SuspendExecution, InterruptedException {                    SuspendableRunnable runnable = null;                    while (true){                        try{                            //取任务,没有则阻塞。                            runnable = taskQueue.take();                        }catch (Exception e){                            System.out.println(e.getMessage());                        }                        //存在任务则运行。                        if(runnable != null){                            runnable.run();                        }                        runnable = null;                    }                }            });  //new一个工做协程            workThreads[i].start();  //启动工做协程        }        Runtime.getRuntime().availableProcessors();    }    //执行任务,其实就是把任务加入任务队列,何时执行由协程池管理器决定    public void execute(SuspendableRunnable task) {        try {            taskQueue.put(task);   //put:阻塞接口的插入        } catch (Exception e) {            // TODO: handle exception            System.out.println("阻塞");        }    }    //销毁协程池,该方法保证全部任务都完成的状况下才销毁全部协程,不然等待任务完成再销毁    public void destory() {        //工做协程中止工做,且置为null        System.out.println("ready close thread...");        for (int i = 0; i < workerNum; i++) {            workThreads[i] = null; //help GC        }        taskQueue.clear();  //清空等待队列    }    //覆盖toString方法,返回协程信息:工做协程个数和已完成任务个数    @Override    public String toString() {        return "WorkThread number:" + workerNum + " ==分割线== wait task number:" + taskQueue.size();    }}

测试代码:

package com.example.ai;import co.paralleluniverse.strands.SuspendableRunnable;import lombok.SneakyThrows;import org.springframework.boot.autoconfigure.SpringBootApplication;import java.util.concurrent.CountDownLatch;@SpringBootApplicationpublic class AiApplication {    @SneakyThrows    public static void main(String[] args) {        //等待协程任务完毕后再结束主线程        CountDownLatch cdl = new CountDownLatch(50);        //开启5个协程,50个任务列队。        WorkTools myThreadPool = new WorkTools(5, 50);        for (int i = 0; i< 50; i++){            int finalI = i;            myThreadPool.execute(new SuspendableRunnable() {                @Override                public void run() {                    System.out.println(finalI);                    try {                        //延迟1秒                        Thread.sleep(1000);                        cdl.countDown();                    } catch (InterruptedException e) {                        System.out.println("阻塞中");                    }                }            });        }        //阻塞        cdl.await();    }}

Java基于quasar如何实现协程池

以上就是Java基于quasar如何实现协程池的详细内容了,看完之后是否有所收获呢?如果想了解更多相关内容,欢迎来编程网精选!

--结束END--

本文标题: Java基于quasar如何实现协程池

本文链接: https://lsjlt.com/news/342085.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java基于quasar如何实现协程池
    这篇文章主要介绍了Java基于quasar如何实现协程池,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。业务场景:golang与swoole都拥抱了协程,在同任务并发数量下,协程可比线程多几倍。所以最近在查询java时了解...
    99+
    2023-07-02
  • java基于quasar怎么实现协程池
    这篇文章主要讲解了“java基于quasar怎么实现协程池”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java基于quasar怎么实现协程池”吧!业务场景:golang与swoole都拥抱...
    99+
    2023-07-02
  • java基于quasar实现协程池的方法示例
    业务场景:golang与swoole都拥抱了协程,在同任务并发数量下,协程可比线程多几倍。所以最近在查询java时了解java本身是没有协程的,但是某牛自行实现了协程,也就是本文的主...
    99+
    2024-04-02
  • java协程框架quasar和kotlin中的协程实例分析
    这篇文章主要介绍“java协程框架quasar和kotlin中的协程实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“java协程框架quasar和kotlin中的协程实例分析”文章能帮助大家解...
    99+
    2023-06-29
  • Java基于IDEA如何实现http编程
    这篇文章主要介绍了Java基于IDEA如何实现http编程,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。java基本数据类型有哪些Java的基本数据类型分为:1、整数类型,用...
    99+
    2023-06-14
  • 基于Golang如何实现Redis协议解析器
    这篇文章主要介绍了基于Golang如何实现Redis协议解析器的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇基于Golang如何实现Redis协议解析器文章都会有所收获,下面我们一起来看看吧。RESP协议RES...
    99+
    2023-07-05
  • 基于node实现websocket协议
    一、协议 WebSocket是一种基于TCP之上的客户端与服务器全双工通讯的协议,它在HTML5中被定义,也是新一代webapp的基础规范之一。 它突破了早先的AJAX的限制,关键在于实时性,服务器可以主动...
    99+
    2022-06-04
    协议 node websocket
  • Java实现基于UDP协议的网络通信UDP编程
    目录UDP编程通信基本介绍基本流程UDP编程通信 基本介绍 类DatagramSocket和DatagramPacket【数据包/数据报】实现了基于UDP协议网络程序。UDP数据报通...
    99+
    2023-05-17
    Java UDP编程 Java UDP网络编程
  • java实现基于UDP协议的聊天小程序操作
    UDP(User Data Protocol,用户数据报协议)是与TCP相对应的协议。它是面向非连接的协议,它不与对方建立连接,而是直接就把数据包发送过去! UDP适用于一次只传送少...
    99+
    2024-04-02
  • Java如何实现基于用户的协同过滤推荐算法
    小编给大家分享一下Java如何实现基于用户的协同过滤推荐算法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!协同过滤简单来说是利用某兴趣相投、拥有共同经验之群体的喜好来推荐用户感兴趣的信息,个人通过合作的机制给予信息相当程度...
    99+
    2023-05-30
    java
  • Java基于TCP如何实现简单聊天程序
    本篇内容介绍了“Java基于TCP如何实现简单聊天程序”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、如何实现TCP通信要实现TCP通信需...
    99+
    2023-06-29
  • 如何实现java简单的线程池
    这篇文章主要讲解了“如何实现java简单的线程池”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何实现java简单的线程池”吧!目录拆分实现流程实现方式拒绝策略阻塞队列线程池和工作线程策略模...
    99+
    2023-06-20
  • Golang协程池gopool设计与实现
    目录Goroutine协程池gopool核心实现PoolTaskWorker整体来看三个角色的定位使用 sync.Pool 进行性能优化Goroutine Goroutine 是 G...
    99+
    2024-04-02
  • Golang协程池的实现与应用
    目录1. 为什么需要协程池2. 使用协程池的优点3. 设计思路4. 实现一个简单的协程池4.1 Task 任务对象4.2 Pool协程池4.3 Main函数1. 为什么需要协程池 使...
    99+
    2023-05-19
    Golang协程池 Go协程池使用
  • Java网络编程之基于TCP协议
    目录一、单向通信二、双向通信三、对象流传送四、加入完整的处理异常方式五、多线程接收用户请求一、单向通信 功能:客户端发送一句话到服务器: 客户端: public class ...
    99+
    2024-04-02
  • Go简单实现协程池的实现示例
    目录MPG模型通道的特性首先就是进程、线程、协程讲解老三样。 进程: 本质上是一个独立执行的程序,进程是操作系统进行资源分配和调度的基本概念,操作系统进行资源分配和调度的一...
    99+
    2024-04-02
  • Java如何实现基于数组的表
    这篇文章将为大家详细讲解有关Java如何实现基于数组的表,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。没看过 其他语言版的数据结构,但觉得java的实现方法很巧妙--用类和对象来实现.基于数组的表,思想很...
    99+
    2023-06-03
  • Java如何使用线程池实现socket编程
    这篇文章主要讲解了“Java如何使用线程池实现socket编程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java如何使用线程池实现socket编程”吧!前言以多个客户端和一个服务端的so...
    99+
    2023-06-29
  • Java中线程池自定义如何实现
    这篇“Java中线程池自定义如何实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java中线程池自定义如何实现”文章吧。线...
    99+
    2023-07-05
  • GO实现协程池管理的方法
    使用channel实现协程池 通过 Channel 实现 Goroutine Pool,缺点是会造成协程的频繁开辟和注销,但好在简单灵活通用。 package main imp...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作