深入理解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)存的變量,把鎖定的變量釋放出來(lá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ì)所有線程的可見(jiàn)性,對(duì)于非原子性的操作,仍然不是線程安全的。
2 禁止指令重排序優(yōu)化。
原子性、可見(jiàn)性與有序性
先行先發(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í)間
無(wú)限期等待 Waiting 處于這種狀態(tài)的線程不會(huì)被分配CPU執(zhí)行時(shí)間,它們要等待被其它線程顯式地喚醒:沒(méi)有設(shè)置Timeout參數(shù)的Object.wait()方法;沒(méi)有設(shè)置Timeout參數(shù)的Thread.join()方法;LockSupport.park()方法
限期等待 Timed Waiting 處于這種狀態(tài)的線程也不會(huì)被分配CPU執(zhí)行時(shí)間,不過(guò)無(wú)須等待被期它線程顯式地喚醒,在一定時(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. moment轉(zhuǎn)化時(shí)間戳出現(xiàn)Invalid Date的問(wèn)題及解決2. python爬蟲實(shí)戰(zhàn)之制作屬于自己的一個(gè)IP代理模塊3. WML的簡(jiǎn)單例子及編輯、測(cè)試方法第1/2頁(yè)4. Ajax返回值類型與用法實(shí)例分析5. .NET6打包部署到Windows Service的全過(guò)程6. 解決ajax請(qǐng)求后臺(tái),有時(shí)收不到返回值的問(wèn)題7. 開(kāi)發(fā)效率翻倍的Web API使用技巧8. asp批量添加修改刪除操作示例代碼9. 使用JSP技術(shù)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的在線測(cè)試系統(tǒng)的實(shí)例詳解10. HTML 絕對(duì)路徑與相對(duì)路徑概念詳細(xì)
