黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 詳解線程上下文切換

詳解線程上下文切換

更新時間:2020-11-20 17:56:49 來源:動力節點 瀏覽2624次

對于單核 CPU,CPU 在一個時刻只能運行一個線程,當在運行一個線程的過程中轉去運行另外一個線程,這個叫做線程上下文切換。


由于可能當前線程的任務并沒有執行完畢,所以在切換時需要保存線程的運行狀態,以便下次重新切換回來時能夠繼續切換之前的狀態運行。舉個簡單的例子:比如一個線程A正在讀取一個文件的內容,正讀到文件的一半,此時需要暫停線程A,轉去執行線程B,當再次切換回來執行線程A的時候,我們不希望線程A又從文件的開頭來讀取。


因此需要記錄線程A的運行狀態,那么會記錄哪些數據呢?因為下次恢復時需要知道在這之前當前線程已經執行到哪條指令了,所以需要記錄程序計數器的值,另外比如說線程正在進行某個計算的時候被掛起了,那么下次繼續執行的時候需要知道之前掛起時變量的值時多少,因此需要記錄CPU寄存器的狀態。所以一般來說,線程上下文切換過程中會記錄程序計數器、CPU寄存器狀態等數據。


簡而言之:對于線程的上下文切換實際上就是 存儲和恢復CPU狀態的過程,它使得線程執行能夠從中斷點恢復執行。


既然上下文切換會帶來開銷,給CPU帶來負擔,那么我們該如何減少線程上下文切換呢?


1 .減少線程的數量

由于一個CPU每個時刻只能執行一條線程,而傲嬌的我們又想讓程序并發執行,操作系統只好不斷地進行上下文切換來使我們從感官上覺得程序是并發執的行。因此,我們只要減少線程的數量,就能減少上下文切換的次數。然而如果線程數量已經少于CPU核數,每個CPU執行一條線程,照理來說CPU不需要進行上下文切換了,但事實并非如此。


2 .控制同一把鎖上的線程數量

如果多條線程共用同一把鎖,那么當一條線程獲得鎖后,其他線程就會被阻塞;當該線程釋放鎖后,操作系統會從被阻塞的線程中選一條執行,從而又會出現上下文切換。因此,減少同一把鎖上的線程數量也能減少上下文切換的次數。


3 .采用無鎖并發編程

需要并發執行的任務是無狀態的:HASH分段

所謂無狀態是指并發執行的任務沒有共享變量,他們都獨立執行。對于這種類型的任務可以按照ID進行HASH分段,每段用一條線程去執行。

需要并發執行的任務是有狀態的:CAS算法

如果任務需要修改共享變量,那么必須要控制線程的執行順序,否則會出現安全性問題。你可以給任務加鎖,保證任務的原子性與可見性,但這會引起阻塞,從而發生上下文切換;為了避免上下文切換,你可以使用CAS算法,僅在線程內部需要更新共享變量時使用CAS算法來更新,這種方式不會阻塞線程,并保證更新過程的安全性。


因此,盡管多線程可以使得任務執行的效率得到提升,但由于在線程切換時同樣會帶來一定的開銷代價,并且多個線程會導致系統資源占用的增加,所以在進行多線程編程時要注意這些因素。好了,線程上下文切換就講到這里,想要掌握更多的多線程知識的小伙伴抓緊時間攻克本站的Java多線程教程吧!


提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 韩国午夜伦理 | 国产操操操 | 一级人做人a爰免费视频 | 你懂的在线视频播放 | 在线观看亚洲欧美 | 日本看片网址 | 中文字幕欧美日韩 | 男人午夜禁片在线观看 | 黄色骚视频 | 成人免费黄色 | 日韩小视频在线播放 | 国产农村精品一级毛片视频 | 好吊日在线观看 | 日韩国产在线播放 | 日本一区二区不卡久久入口 | 欧美日韩中文字幕一区二区高清 | 国产亚洲情侣一区二区无 | 性欧美video另类hd亚洲人 | 免费的成人a视频在线观看 免费的a级毛片 | 天天做天天爱天天影视综合 | 国产18视频 | 色综合手机在线 | 日韩中文字幕在线免费观看 | aaa一级 | 亚洲欧美日韩在线观看播放 | 天天射天天射天天干 | 午夜激情福利在线 | 色视频在线观看 | 国产色视频网站免费观看 | 最近最好的中文字幕2019免费 | 日日摸夜夜摸狠狠摸日日碰夜夜做 | 老司机免费午夜精品视频 | 青青草国产三级精品三级 | 波多野结衣一区二区三区高清在线 | 可以免费看的黄色片 | 一区二区三区鲁丝不卡麻豆 | 日韩一级一欧美一级国产 | 任你躁欧美一级在线精品 | 丁香六月婷婷综合 | 在线播放人成午夜免费视频 | 国产成人经典三级在线观看 |