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