摘要:本周提交的一份增強建議草案要求將虛擬線程作為標準版的一部分進行預覽。虛擬線程目的是更好地支持編寫和維護高吞吐量并發應用程序。該提案指出,使用虛擬線程不需要學習新的編程模型。
我們知道 Go 語言最大亮點之一就是原生支持并發,這得益于 Go 語言的協程機制。一個 go 語句就可以發起一個協程 (goroutin)。
協程本質上是一種用戶態線程,它不需要操作系統來進行調度,而是由用戶程序自行管理和調度。它寄存于線程中,系統開銷極小,可以顯著的提高性能和并發能力。使用協程的優點是運行效率高、編程簡單、結構清晰。目前,原生支持協程的語言不是很多。
Oracle 本周提交的一份JDK增強建議(JEP)草案要求將虛擬線程作為Java標準版的一部分進行預覽。
虛擬線程類似于 Go 語言的協程,將補充Java的平臺線程(代表操作系統線程),采用輕量級的用戶模式線程實現,將更有效地利用可用的硬件,并大大降低成本。
虛擬線程目的是更好地支持編寫和維護高吞吐量并發應用程序。
該提案指出,線程對于代表一個并發單元(如事務)是很有用的。Java目前對Thread的實現是為每個Java線程消耗一個操作系統線程,而操作系統線程是稀缺和昂貴的。現代服務器的能力可以處理比操作系統線程更多數量級的并發事務。
編寫高吞吐量服務器軟件的開發者不得不在事務之間共享線程,以有效利用硬件。這是用線程池來完成的,它將線程借給一個又一個事務,以節省為每個事務創建線程的成本。當這還不夠時,開發人員開始將線程返回到線程池中,甚至在事務的中間,在等待I/O的時候。但是,這導致了一種異步的編程風格,需要一套獨立的、不兼容的API,并使故障排除、調試、觀察和分析變得非常困難。
虛擬線程是java.lang.Thread的用戶模式實現,它不會阻塞操作系統線程,能夠實現接近最佳的硬件利用率。虛擬線程允許高水平的并發,以及高吞吐量,同時程序仍然與Java平臺和工具的基于線程的設計相協調。虛擬線程對于平臺線程來說,就像虛擬內存對于物理RAM一樣:一種通過自動映射到底層物理資源而提供豐富的 "虛擬 "資源的機制。
該提案指出,使用虛擬線程不需要學習新的編程模型。使用Java編寫并發應用程序的開發者已經知道這個模型。然而,開發人員需要改變由于線程的高成本而產生的舊習慣,特別是使用線程池,這些線程池只有在它們所匯集的資源稀缺或創建成本高昂時才有用。
虛擬線程是由JDK實現的java.lang.Thread的實例,它允許許多活動實例在同一進程中共存。虛擬線程的語義與平臺線程相同,只是它們屬于單一的ThreadGroup,不能被枚舉。
?
參考資料:
1.?進程、線程和協程的區別
2. 編程寶庫
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/123994.html
摘要:經過半年的沉淀,加上對,和分布式這塊的補齊,終于開始重拾面試信心,再次出征。面試官提示沒有提到線程的有內核態的切換,程只在用戶態調度。三面綜合技術面這面面的是陣腳大亂,面試官采用刨根問底的方式提問,終究是面試經驗不夠,導致面試的節奏有點亂。 經過半年的沉淀,加上對MySQL,redis和分布式這塊的補齊,終于開始重拾面試信心,再次出征。 鵝廠 面試職位:go后端開發工程師,接受從Jav...
摘要:前言并發編程的目的是讓程序跑的更快,但并不是啟動更多的線程,這個程序就跑的更快。盡可能降低上下文切換的次數,有助于提高并發效率。死鎖并發編程中的另一挑戰是死鎖,會造成系統功能不可用。 前言 并發編程的目的是讓程序跑的更快,但并不是啟動更多的線程,這個程序就跑的更快。有以下幾種挑戰。 挑戰及方案 上下文切換 單核CPU上執行多線程任務,通過給每個線程分配CPU時間片的方式來實現這個機制。...
摘要:概述本系列文章將從開發者角度梳理開發實時聯網游戲后臺服務過程中可能面臨的挑戰,并針對性地提供相應解決思路,期望幫助開發者依據自身游戲特點做出合理的技術選型。多路復用避免了讀寫阻塞,減少了上下文切換,提升了利用率和系統吞吐率。 概述:本系列文章將從開發者角度梳理開發實時聯網游戲后臺服務過程中可能面臨的挑戰,并針對性地提供相應解決思路,期望幫助開發者依據自身游戲特點做出合理的技術選型。 關...
摘要:它避免了上下文切換的額外耗費,兼顧了多線程的優點,簡化了高并發程序的復雜。而可以理解為一種語言的協程。線程輕量級進程,,是程序執行流的最小單元。一個標準的線程由線程,當前指令指針,寄存器集合和堆棧組成。其實就是或者等語言中的多線程開發。 grape 全部視頻:https://segmentfault.com/a/11... 原視頻地址:https://biglive.xueersi.c...
摘要:因為多線程競爭鎖時會引起上下文切換。減少線程的使用。舉個例子如果說服務器的帶寬只有,某個資源的下載速度是,系統啟動個線程下載該資源并不會導致下載速度編程,所以在并發編程時,需要考慮這些資源的限制。 最近私下做一項目,一bug幾日未解決,總惶恐。一日頓悟,bug不可怕,怕的是項目不存在bug,與其懼怕,何不與其剛正面。 系列文章傳送門: Java多線程學習(一)Java多線程入門 Jav...
閱讀 2781·2021-11-19 11:30
閱讀 3065·2021-11-15 11:39
閱讀 1787·2021-08-03 14:03
閱讀 1995·2019-08-30 14:18
閱讀 2050·2019-08-30 11:16
閱讀 2162·2019-08-29 17:23
閱讀 2605·2019-08-28 18:06
閱讀 2540·2019-08-26 12:22