深入理解java虛擬機(jī)-第12章Java內(nèi)存模型與線程
Java內(nèi)存模型
主內(nèi)存與工作內(nèi)存:
java內(nèi)存模型規(guī)定了所有的變量都在主內(nèi)存中,每條線程還有自己的工作內(nèi)存。
工作內(nèi)存中保存了該線程使用的主內(nèi)存副本拷貝,線程對(duì)變量的所有操作都必須在工作內(nèi)存中進(jìn)行。
內(nèi)存間交互操作:
1 lock 作用于主內(nèi)存的變量,它把一個(gè)變量標(biāo)識(shí)為一個(gè)線程獨(dú)占的狀態(tài)。
2 unlock 作用于主內(nèi)存的變量,把鎖定的變量釋放出來
3 read 作用于工作內(nèi)存的變量,把一個(gè)變量的值從主內(nèi)存?zhèn)鬏數(shù)骄€程的工作內(nèi)存中。
4 load 作用于工作內(nèi)存的變量,它把read操作從主內(nèi)存中得到的變量值放入工作內(nèi)存的變量副本中
5 use 作用于工作內(nèi)存的變量 把工作內(nèi)存中一個(gè)變量的值傳遞給執(zhí)行引擎
6 assign 作用于工作內(nèi)存的變量, 把一個(gè)從執(zhí)行引擎收到的值賦給工作內(nèi)存的變量
7 store 作用天工作內(nèi)存的變量,把工作內(nèi)存中一個(gè)變量的值傳送到主內(nèi)存中。
8 write 作用于主內(nèi)存的變量,把store操作從工作內(nèi)存中得到的變量的值放入主內(nèi)存中
當(dāng)一個(gè)變量定義為volatile后,它將具備兩種特性
1 保證此變量對(duì)所有線程的可見性,對(duì)于非原子性的操作,仍然不是線程安全的。
2 禁止指令重排序優(yōu)化。
原子性、可見性與有序性
先行先發(fā)原則
Java線程的狀態(tài)轉(zhuǎn)換
新建 New 創(chuàng)建后沿未啟動(dòng)的純種處于這種狀態(tài)
運(yùn)行 Runnable 包括了操作系統(tǒng)線程狀態(tài)中的Running和Ready,處于此狀態(tài)的線程有可能正在執(zhí)行,也有可能正在等等著CPU為它分配執(zhí)行時(shí)間
無限期等待 Waiting 處于這種狀態(tài)的線程不會(huì)被分配CPU執(zhí)行時(shí)間,它們要等待被其它線程顯式地喚醒:沒有設(shè)置Timeout參數(shù)的Object.wait()方法;沒有設(shè)置Timeout參數(shù)的Thread.join()方法;LockSupport.park()方法
限期等待 Timed Waiting 處于這種狀態(tài)的線程也不會(huì)被分配CPU執(zhí)行時(shí)間,不過無須等待被期它線程顯式地喚醒,在一定時(shí)間后它們會(huì)由系統(tǒng)自動(dòng)喚醒: Thread.sleep()方法;設(shè)置了Timeout參數(shù)的Object.wait()方法;設(shè)置了Thimeout參數(shù)的Thread.join()方法;LockSupport.parkNanos()方法;LockSuport.parkUnitl()方法
阻塞 Blocked 等待著獲取到一個(gè)排他鎖
結(jié)束 Terminated 已終止線程的線程狀態(tài)
相關(guān)文章:
1. 基于 Python 實(shí)踐感知器分類算法2. Python如何批量生成和調(diào)用變量3. ASP.Net Core對(duì)USB攝像頭進(jìn)行截圖4. python利用opencv實(shí)現(xiàn)顏色檢測(cè)5. ASP.Net Core(C#)創(chuàng)建Web站點(diǎn)的實(shí)現(xiàn)6. Python 中如何使用 virtualenv 管理虛擬環(huán)境7. Python獲取B站粉絲數(shù)的示例代碼8. 通過CSS數(shù)學(xué)函數(shù)實(shí)現(xiàn)動(dòng)畫特效9. windows服務(wù)器使用IIS時(shí)thinkphp搜索中文無效問題10. ASP.NET MVC實(shí)現(xiàn)橫向展示購物車
