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