Java线程调度
線程調度指的是系統為線程分配CPU使用權的方式。主要有協同式線程調度和搶占式線程調度。
協同式線程調度(Cooperative Threads-Scheduling)
在多線程系統中,線程的執行時間由線程自身控制,執行結束后要主動通知系統切換到另一線程。
優劣勢
- 實現簡單,由于線程執行結束后才會進行線程轉換,切換操作對線程可見,所以不存在線程同步問題
- 線程執行時間不可控,如果一個線程實現有問題,一直不通知系統進行線程切換,那整個系統就會阻塞
搶占式線程調度(Preemptive Threads-Scheduling)
在多線程系統中,每個線程由系統來分配執行時間,線程的切換不由線程本身控制(Java的Thread.yield()可以讓出執行時間,但是無法主動獲取執行時間)
優劣勢
- 線程的執行時間是可控的,不會由于一個線程導致整個進程阻塞,Java采用的是這種調度方式
- 進程不能控制自身的執行,系統會進行時間片的切分,會涉及到上下文的保存,線程同步等問題,實現較復雜
JVM的實現:
JVM規范中規定每個線程都有優先級,且優先級越高越優先執行,但優先級高并不代表能獨自占用執行時間片,可能是優先級高得到越多的執行時間片,反之,優先級低的分到的執行時間少但不會分配不到執行時間。
java使用的線程調度式搶占式調度
Java中線程會按優先級分配CPU時間片運行
線程讓出cpu的情況:
- 當前運行線程主動放棄CPU,JVM暫時放棄CPU操作,如調用yield()方法
- 當前運行線程因為某些原因進入阻塞狀態,例如阻塞在I/O上
- 線程結束(Dead)
總結
- 上一篇: matlab中线形_MATLAB在绘图时
- 下一篇: 杭州幼儿园汇总