亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java基于quasar怎么實現協程池

發布時間:2022-06-22 13:52:22 來源:億速云 閱讀:111 作者:iii 欄目:開發技術

這篇文章主要講解了“java基于quasar怎么實現協程池”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“java基于quasar怎么實現協程池”吧!

業務場景:golang與swoole都擁抱了協程,在同任務并發數量下,協程可比線程多幾倍。所以最近在查詢java時了解java本身是沒有協程的,但是某牛自行實現了協程,也就是本文的主角quasar(纖程)!在csdn中基本都是對它的基本使用,用法和線程差不多。不過沒看到誰公開一下手寫協程池的騷操作(誰會直接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;
 
 
 
@SpringBootApplication
 
 
public 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怎么實現協程池”的內容了,經過本文的學習后,相信大家對java基于quasar怎么實現協程池這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

九寨沟县| 赤水市| 碌曲县| 综艺| 调兵山市| 婺源县| 上饶县| 商河县| 江安县| 那曲县| 高淳县| 阿巴嘎旗| 香港| 新野县| 嘉祥县| 瑞金市| 盘山县| 甘谷县| 哈尔滨市| 盐池县| 青海省| 英吉沙县| 宜昌市| 都兰县| 大宁县| 盐城市| 桦南县| 石屏县| 濮阳县| 石棉县| 瓦房店市| 新营市| 临沭县| 集贤县| 铜陵市| 溧水县| 新和县| 靖江市| 兴隆县| 江城| 新郑市|