內(nèi)核線程優(yōu)先級設(shè)置的方法介紹
個人理解,內(nèi)核級線程和進程是一樣的,前者與POSIX線程(pthread)有很大的區(qū)別。因此,內(nèi)核的進程調(diào)度策略和系統(tǒng)調(diào)用也適用于內(nèi)核級線程。
調(diào)度策略有三種:
1.SCHED_NORMAL 非實時調(diào)度策略,默認情況下是100~139,由nice值決定;
2.SCHED_FIFO實時調(diào)度策略,先到先服務(wù)。一旦占用cpu則一直運行。一直運行直到有更高優(yōu)先級任務(wù)到達或自己放棄
3.SCHED_RR實時調(diào)度策略,時間片輪轉(zhuǎn)。當進程的時間片用完,系統(tǒng)將重新分配時間片,并置于就緒隊列尾。同樣可以被高優(yōu)先級搶占。
兩種實時優(yōu)先級范圍在0至MAX_RT_PRIO-1之間,默認為0到99。
相關(guān)的系統(tǒng)調(diào)用(來自于LKD,不同內(nèi)核可能有所不同):
| nice() | 設(shè)置進程的nice值 |
| sched_setscheduler() | 設(shè)置進程的調(diào)度策略 |
| sched_getscheduler() | 獲取進程的調(diào)度策略 |
| sched_setparam() | 設(shè)置進程的實時優(yōu)先級 |
| sched_getparam() | 獲取進程的實時優(yōu)先級 |
| sched_get_priority_max() | 獲取實時優(yōu)先級的最大值 |
| sched_get_priority_min() | 獲取實時優(yōu)先級的最小值 |
| sched_rr_get_interval() |
獲取進程的時間片值 |
| sched_setaffinity() | 設(shè)置進程的處理器的親和力 |
| sched_getaffinity() | 獲取進程的處理器的親和力 |
| sched_yield() | 暫時讓出處理器 |
設(shè)置時需要用到struct sched_param這個結(jié)構(gòu)。
以下為我寫的內(nèi)核線程中的部分代碼:
struct sched_param param;
param.sched_priority = 99;
sched_setscheduler(current, SCHED_FIFO, ¶m)//出錯時返回-1
相關(guān)文章
C++中動態(tài)綁定和內(nèi)存管理的實現(xiàn)
本文主要介紹了C++中動態(tài)綁定和內(nèi)存管理的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-12-12
C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式
這篇文章主要介紹了C++筆記-設(shè)置cout輸出數(shù)據(jù)的寬度和填充方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11
詳解C++?functional庫中的仿函數(shù)使用方法
仿函數(shù)(functor)又稱之為函數(shù)對象(function?object),實際上就是?重載了()操作符?的?struct或class。本文將詳細講解C++中仿函數(shù)的使用方法,需要的可以參考一下2022-04-04
C++ 多線程編程建議之 C++ 對多線程/并發(fā)的支持(下)
這篇文章主要介紹的是 C++ 多線程編程建議之 C++ 對多線程/并發(fā)的支持的相關(guān)資料,承接前文 現(xiàn)代 C++ 對多線程/并發(fā)的支持,接下來我們看看回發(fā)生什么吧2021-10-10

