Java 线程调度
什么是線程調(diào)度
線程調(diào)度是指 OS 為線程分配處理器使用權(quán)的過程, 主要的調(diào)度方式有兩種:
- 協(xié)同式線程調(diào)度。
- 搶占式線程調(diào)度。
協(xié)同式線程調(diào)度
線程的執(zhí)行時間由線程本身來控制, 線程把自己的工作執(zhí)行完了之后,要主動通知 OS 切換到另一個線程上,即相當(dāng)于在線程執(zhí)行時間內(nèi)能保證獨占一個處理器資源。
優(yōu)點:不存在線程同步的問題。 缺點:線程執(zhí)行時間不可控制,如果一個線程編寫有問題,一直不告知OS進(jìn)行線程切換,那么程序?qū)⒁恢弊枞?搶占式線程調(diào)度
線程的執(zhí)行時間不由線程本身來控制, 而是由 OS 來統(tǒng)一分配,在線程執(zhí)行時間內(nèi)不能保證獨占一個處理器資源。
優(yōu)點:不會因為某個線程出問題導(dǎo)致整個程序阻塞。 缺點:會有線程同步的問題。Java 的線程調(diào)度方式
Java 的線程調(diào)度方式是搶占式線程調(diào)度。
也就是每個線程的執(zhí)行時間多少由 OS 來決定,但是盡管如此,我們還是可以通過給線程設(shè)置優(yōu)先級來"建議" OS 給某些線程多分配一些執(zhí)行時間。Java一共設(shè)置了 10 個級別的線程優(yōu)先級,在兩個線程同時處于就緒狀態(tài)時,優(yōu)先級越高的線程越容易被系統(tǒng)選擇執(zhí)行。
可以用優(yōu)先級來判斷兩個同處于就緒狀態(tài)的線程的執(zhí)行順序嗎?
答案是: 否!
最根本的原因在于 Java 的線程是通過映射到 OS 的原生線程上來實現(xiàn)的,所以線程調(diào)度最終還是取決于 OS。詳細(xì)原因如下:
- 在不同的 OS 環(huán)境下,當(dāng) Java 線程映射到 OS 的原生線程上時,有可能出現(xiàn)不同優(yōu)先級的線程變得相同的情況。例如, Windows 中的線程優(yōu)先級只有 7 種,那就意味著 Java 線程的 10 個優(yōu)先級在映射到 OS 原生線程上時肯定會出現(xiàn)不同的優(yōu)先級映射成同一個優(yōu)先級的現(xiàn)象。
- 優(yōu)先級有可能會被 OS 自行改變。
總結(jié)
- 上一篇: 虚拟机登服务器,用虚拟机登录云服务器
- 下一篇: java 0l是多少_Java 构造器