《你必须知道的261个java语言问题》读书报告——第二弹
1.java中的線程調(diào)度
1.1 分時調(diào)度與時間調(diào)度
計算機通常只有一個CPU,在任意時刻只能一條機器指令,每個線程只有獲得CPU的使用權(quán)才能執(zhí)行命令.所謂的多線程的并發(fā)運行,其實是指從宏觀上看.各個線程輪流或者CPU的使用權(quán),分別執(zhí)行各自的任務.在可運行池中,會有多個處于就緒狀態(tài)的線程在等待CPU,JAVA虛擬機的一項任務就是負責線程的調(diào)度。線程的調(diào)度是指按照特定的機制為多個線程分配CPU使用權(quán)。
有兩種調(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。一個線程會因為以下原因而放棄CPU:
?? (1) java虛擬機讓當前線程暫時放棄CPU,轉(zhuǎn)到就緒狀態(tài),使其它線程或者運行機會。
?? (2) 當前線程因為某些原因而進入阻塞狀態(tài)
?? (3) 線程結(jié)束運行
?? PS:需要注意的是,線程的調(diào)度不是跨平臺的,它 不僅僅取決于java虛擬機,還依賴于操作系統(tǒng)。在某些操作系統(tǒng)中,只要運行中的線程沒有遇到阻塞,就不會放棄CPU;在某些操作系統(tǒng)中,即使線程沒有遇到阻塞,也會運行一段時間后放棄CPU,給其它線程運行的機會。
1.2 java中的的調(diào)度方法
??? java的線程調(diào)度是不分時的,同時啟動多個線程后,不能保證各個線程輪流獲得均等的CPU時間片。
??? 如果希望明確地讓一個線程給另外一個線程運行的機會,可以采取以下辦法之一。
?????????????? 調(diào)整各個線程的優(yōu)先級
?????????????? 讓處于運行狀態(tài)的線程調(diào)用Thread.sleep()方法
?????????????? 讓處于運行狀態(tài)的線程調(diào)用Thread.yield()方法
?????????????? 讓處于運行狀態(tài)的線程調(diào)用另一個線程的join()方法
轉(zhuǎn)載于:https://www.cnblogs.com/mengyan/archive/2012/10/05/2712129.html
與50位技術(shù)專家面對面20年技術(shù)見證,附贈技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的《你必须知道的261个java语言问题》读书报告——第二弹的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Tcpdump使用详解
- 下一篇: css结构和重叠之选择器的特殊性