欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java21虛擬線程實踐

 更新時間:2023年10月11日 15:00:36   作者:xindoo  
java21正式版發(fā)布了,為我們帶來了很多新的特性,其中我最感興趣的就是虛擬線程,本文主要介紹了Java21虛擬線程實踐,感興趣的可以;了解一下

就在前幾天,java21正式版發(fā)布了,作為繼java17之后的又一個長期支持版本 (LTS),為我們帶來了很多新的特性,其中我最感興趣的就是虛擬線程(virtual thread),相信大家對虛擬線程也很好奇。趁著空閑時間安裝了jdk21來體驗一把,順便把我查到的關(guān)于java21虛擬線程相關(guān)的資料也分享下。

虛擬線程的使用

首先來看下虛擬線程怎么使用,jdk21在Thread類中,專門提供了虛擬線程和虛擬線程工廠的創(chuàng)建入口,我們挨個看下。首先就是虛擬線程的創(chuàng)建和啟動,使用lambda也就幾行代碼:

        Thread.ofVirtual().start(() -> {
            System.out.println("Hello, virtual thread!");
        });
        // 也可以指定虛擬線程的名字
        Thread.ofVirtual().name("virtual thread").start(() -> {
            System.out.println("Hello, virtual thread!");
        });

Thread也提供了虛擬線程工廠,有了虛擬線程工廠,我們就可以在ExecutorService中使用虛擬線程。當(dāng)然Executors已經(jīng)提供好了封裝,我們直接調(diào)用即可:

        try (var executor = Executors.newVirtualThreadPerTaskExecutor()) {
            IntStream.range(1, 10_000).forEach(i -> {
                executor.submit(() -> {
                    Thread.sleep(Duration.ofSeconds(0));
                    return i;
                });
            });
        }

可以看得出來,虛擬線程幾乎沒有啥使用門檻,那他到底和普通線程有啥區(qū)別?我在查閱了一些資料后,我的理解如下:(可能理解淺薄或者有些錯誤,請指正)

什么是虛擬線程

虛擬線程是一種輕量化的線程封裝,由jvm直接調(diào)度和管理。反之普通的線程其實是調(diào)用的操作系統(tǒng)的能力,對應(yīng)的是操作系統(tǒng)級的線程。相對虛擬線程來說操作系統(tǒng)級的線程持有成本很高,而且受操作系統(tǒng)調(diào)度和管理的。實際在普通多線程情況下,如果出現(xiàn)IO阻塞,這個線程就必須得跟著阻塞,這個線程對應(yīng)的操作系統(tǒng)就被阻塞,而他卻持有大量的內(nèi)存。另外,要處理大量的IO就得新建更多線程,而大量的線程會在操作系統(tǒng)調(diào)度時因上下文切換導(dǎo)致大量的CPU被浪費。

如果我們能在某個普通線程在等待IO返回的情況下,讓其運行其他的任務(wù),是不是就可以用少量的線程處理大量的IO?思路很美好,那具體怎么實施呢!在計算機科學(xué)領(lǐng)域,解決問題最簡單的方式就是加一層,比如操作系統(tǒng)中,代碼訪問內(nèi)存中間就有一層虛擬內(nèi)存,如果代碼到線程中間加一層虛擬線程,每個虛擬線程只有在真正需要CPU運行的時候,才會被映射到真正的線程上去運行,而IO阻塞時會換其他非阻塞的虛擬線程上來,這樣就不需要創(chuàng)建大量的線程了,而虛擬線程只需要持有少量的上下文信息即可。

這種實現(xiàn)方式帶來了很多優(yōu)勢,比如:

  • 輕量級:虛擬線程占用內(nèi)存更少,創(chuàng)建和切換代價更低。
  • 支持異步:虛擬線程支持異步非阻塞編程模型。
  • 擴展性好:可以在少量線程上運行大量虛擬線程。
  • 無上下文切換:協(xié)程在同一線程中運行,沒有線程上下文切換。

虛擬線程和協(xié)程

Java21實際上在實現(xiàn)虛擬線程時,兼容了普通線程(不確定是否完全兼容),像ThreadLocal、Semaphore之類的工具完全可以在虛擬線程中使用,基本上大部分使用線程的地方應(yīng)該都可以替換成虛擬線程,也就是說以后可以肆無忌憚創(chuàng)建虛擬線程而不用擔(dān)心過多創(chuàng)建線程了。以上的內(nèi)容看起來很像是go或者python中的協(xié)程,但在medium上看到一篇文章,解釋了Java中的虛擬線程和協(xié)程之間的異同。

相同之處:

  • 虛擬線程和協(xié)程都很輕量級,它們的創(chuàng)建和銷毀開銷小于傳統(tǒng)的操作系統(tǒng)線程。
  • 虛擬線程和協(xié)程都可以通過暫停和恢復(fù)在線程之間切換,從而避免線程上下文切換的開銷。
  • 虛擬線程和協(xié)程都可以以異步和非阻塞的方式處理任務(wù),提高應(yīng)用程序性能和響應(yīng)速度。

不同之處:

  • 虛擬線程在JVM級別實現(xiàn),而協(xié)程在語言級別實現(xiàn)。因此,虛擬線程的實現(xiàn)可以用于任何支持JVM的語言,而協(xié)程的實現(xiàn)需要特定編程語言的支持。
  • 虛擬線程是協(xié)程的基于線程的實現(xiàn),因此可以使用線程相關(guān)的API,如ThreadLocal,Lock和Semaphore。協(xié)程不依賴于線程,通常需要特定的異步編程框架和API。
  • 虛擬線程的調(diào)度由JVM管理,而協(xié)程的調(diào)度由編程語言或異步編程框架管理。因此,虛擬線程可以更好地與其他線程合作,而協(xié)程更適合處理異步任務(wù)。

總結(jié)

有了虛擬線程,我們可以用虛擬線程替換許多使用線程的場景,任何需要異步或者多線程運行的情況下,我們都直接直接扔給虛擬線程去運行,絲毫不用顧慮的過度創(chuàng)建線程的問題,但這里需要額外注意,對于CPU密集型的任務(wù)多線程或者多虛擬線程依舊是無法提升性能的。虛擬線程是否能完全替代普通線程,這點肯定是不可能的,比較很多時候還是需要操作系統(tǒng)去做任務(wù)調(diào)度的,而目前操作系統(tǒng)最小的調(diào)度單位依舊是線程。

總之,Java21正式推遲了虛擬線程,我相信在很多高IO的場景下肯定可以提升性能的,至于具體能提升多少,還是有待于具體數(shù)據(jù)的。

到此這篇關(guān)于Java21虛擬線程實踐的文章就介紹到這了,更多相關(guān)Java21虛擬線程內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MyBatis 實現(xiàn)數(shù)據(jù)的批量新增和刪除的操作

    MyBatis 實現(xiàn)數(shù)據(jù)的批量新增和刪除的操作

    這篇文章主要介紹了MyBatis 實現(xiàn)數(shù)據(jù)的批量新增和刪除的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • 基于Tomcat7、Java、WebSocket的服務(wù)器推送聊天室實例

    基于Tomcat7、Java、WebSocket的服務(wù)器推送聊天室實例

    HTML5 WebSocket實現(xiàn)了服務(wù)器與瀏覽器的雙向通訊,本篇文章主要介紹了基于Tomcat7、Java、WebSocket的服務(wù)器推送聊天室實例,具有一定的參考價值,有興趣的可以了解一下。
    2016-12-12
  • Springboot項目的搭建教程(分離出common父依賴)

    Springboot項目的搭建教程(分離出common父依賴)

    這篇文章主要介紹了Springboot項目的搭建教程(分離出common父依賴),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 詳解Java如何實現(xiàn)與JS相同的Des加解密算法

    詳解Java如何實現(xiàn)與JS相同的Des加解密算法

    這篇文章主要介紹了如何在Java中實現(xiàn)與JavaScript相同的DES(Data Encryption Standard)加解密算法,確保在兩個平臺之間可以無縫地傳遞加密信息,希望對大家有一定的幫助
    2025-04-04
  • Java中指定時區(qū)的3種方法

    Java中指定時區(qū)的3種方法

    這篇文章主要介紹了Java中指定時區(qū)的3種方法,本文是一個JAVA項目和.NET項目通訊時遇到的問題,本文給出JAVA中的3種解決方法,需要的朋友可以參考下
    2015-02-02
  • Springboot如何解決前端請求跨域的問題

    Springboot如何解決前端請求跨域的問題

    這篇文章主要介紹了Springboot如何解決前端請求跨域的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 基于Spring中的事務(wù)@Transactional細節(jié)與易錯點、幻讀

    基于Spring中的事務(wù)@Transactional細節(jié)與易錯點、幻讀

    這篇文章主要介紹了基于Spring中的事務(wù)@Transactional細節(jié)與易錯點、幻讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Spring的Eureka續(xù)約(心跳檢測)詳解

    Spring的Eureka續(xù)約(心跳檢測)詳解

    這篇文章主要介紹了Spring的Eureka續(xù)約(心跳檢測)詳解,eureka?client每隔一定的時間,會給eureka?server發(fā)送心跳,保持心跳,讓eureka?server知道自己還活著,需要的朋友可以參考下
    2023-11-11
  • springBoot的日志文件詳解

    springBoot的日志文件詳解

    日志是程序的重要組成部分,主要可以用來定位和排查問題,在程序中進行自定義日志輸出的時候,也通常是借助于SLF4J框架來輸出日志,本文給大家分享springBoot的日志文件相關(guān)知識,感興趣的朋友一起看看吧
    2024-06-06
  • SpringBoot 改造成https訪問的實現(xiàn)

    SpringBoot 改造成https訪問的實現(xiàn)

    這篇文章主要介紹了SpringBoot 改造成https訪問的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10

最新評論