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