計算機通常只有一個 CPU,在任意時刻只能執(zhí)行一條機器指令,每個線程只有獲得CPU 的使用權(quán)才能執(zhí)行指令。所謂多線程的并發(fā)運行,其實是指從宏觀上看,各個線程輪流獲得 CPU 的使用權(quán),分別執(zhí)行各自的任務(wù)。在運行池中,會有多個處于就緒狀態(tài)的線程在等待 CPU,JAVA 虛擬機的一項任務(wù)就是負責線程的調(diào)度,線程調(diào)度是指按照特定機制為多個線程分配 CPU 的使用權(quán)。(Java是由JVM中的線程計數(shù)器來實現(xiàn)線程調(diào)度)
有兩種調(diào)度模型:分時調(diào)度模型和搶占式調(diào)度模型。
分時調(diào)度模型是指讓所有的線程輪流獲得 cpu 的使用權(quán),并且平均分配每個線程占用的 CPU 的時間片這個也比較好理解。
Java虛擬機采用搶占式調(diào)度模型,是指優(yōu)先讓可運行池中優(yōu)先級高的線程占用CPU,如果可運行池中的線程優(yōu)先級相同,那么就隨機選擇一個線程,使其占用CPU。處于運行狀態(tài)的線程會一直運行,直至它不得不放棄 CPU。