linux中引起線程切換的操作有哪些

 linux中引起線程切換的操作有哪些?針對這個問題,這篇文章給出了相對應(yīng)的分析和解答,希望能幫助更多想解決這個問題的朋友找到更加簡單易行的辦法。       

公司主營業(yè)務(wù):網(wǎng)站設(shè)計制作、網(wǎng)站建設(shè)、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出亳州免費做網(wǎng)站回饋大家。

linux采用一對一的線程模型,用戶線程切換與內(nèi)核線程切換之間的差別非常小。同時,如果忽略用戶主動放棄用戶線程的執(zhí)行權(quán)(yield)帶來的開銷,則只需要考慮內(nèi)核線程切換的開銷。

注意,這里僅僅是為了幫助理解做出的簡化。實際上,用戶線程庫在用戶線程的調(diào)度、同步等過程中做了很多工作,這部分開銷不能忽略。

如JVM對Thread#yield()的解釋:如果底層OS不支持yield的語義,則JVM讓用戶線程自旋至?xí)r間片結(jié)束,線程被動切換,以達到相似的效果。

什么引起線程切換

時間片輪轉(zhuǎn)

線程阻塞

線程主動放棄時間片

直接開銷

直接開銷是線程切換本身引起的,無可避免,必然發(fā)生。

用戶態(tài)與內(nèi)核態(tài)的切換

線程切換只能在內(nèi)核態(tài)完成,如果當(dāng)前用戶處于用戶態(tài),則必然引起用戶態(tài)與內(nèi)核態(tài)的切換。(<font color="red">“用戶態(tài)與內(nèi)核態(tài)的切換”具體帶來什么成本</font>)

上下文切換

前面說線程(或者叫做進程都隨意)信息需要用一個task_struct保存,線程切換時,必然需要將舊線程的task_struct從內(nèi)核切出,將新線程的切入,帶來上下文切換。除此之外,還需要切換寄存器、程序計數(shù)器、線程棧(包括操作棧、數(shù)據(jù)棧)等。

線程調(diào)度算法

線程調(diào)度算法需要管理線程的狀態(tài)、等待條件等,如果根據(jù)優(yōu)先級調(diào)度,則還需要維護優(yōu)先級隊列。如果線程切換比較頻繁,該成本不容小覷。

間接開銷

間接開銷是直接開銷的副作用,取決于系統(tǒng)實現(xiàn)和用戶代碼實現(xiàn)。

緩存缺失

切換進程,需要執(zhí)行新邏輯。如果二者的訪問的地址空間不相近,則會引起緩存缺失,具體影響范圍取決于系統(tǒng)實現(xiàn)和用戶代碼實現(xiàn)。如果系統(tǒng)的緩存較大,則能減小緩存缺失的影響;如果用戶線程訪問數(shù)據(jù)的地址空間接近,則本身的緩存缺失率也比較低。

關(guān)于linux中引起線程切換的操作就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

文章題目:linux中引起線程切換的操作有哪些
本文網(wǎng)址:http://muchs.cn/article12/pdjdgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、靜態(tài)網(wǎng)站、網(wǎng)站營銷手機網(wǎng)站建設(shè)、軟件開發(fā)、建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名