Java并發(fā)學(xué)習(xí)(一):Java內(nèi)存模型

基礎(chǔ)-兩個關(guān)鍵問題

  1. 線程間通信

線程間通信的機制有兩種:1、共享內(nèi)存 : 線程之間通過讀寫程序的公共狀態(tài)進行隱式通信 2、消息傳遞:線程之間通過發(fā)送消息來顯示進行通信,線程間沒有公共狀態(tài)

  1. 線程間同步

同步是指程序中用于控制不同線程間操作發(fā)生相對順序的機制。共享內(nèi)存并發(fā)模型中,同步是顯示進行,程序員必須顯示指定方法或代碼間是互斥執(zhí)行;消息傳遞機制中,同步是隱式進行的

  1. java開發(fā)采用的是共享內(nèi)存模型,線程間通信是隱式執(zhí)行的

堆內(nèi)存與棧內(nèi)存

  • Java的內(nèi)存分為堆內(nèi)存與棧內(nèi)存。堆內(nèi)存主要存放new 創(chuàng)建的對象和數(shù)組;棧內(nèi)存主要存放一些基本類型的變量和對象(或數(shù)組)的引用變量。
  • 對象被創(chuàng)建成功后,存放在堆內(nèi)存里,不能直接訪問,只能通過對象的引用操作該對象
  • 如果堆內(nèi)存中的對象沒有任何變量指向,那么程序?qū)o法再訪問該對象,垃圾回收機制會進行回收,釋放其內(nèi)存空間

Java內(nèi)存模型的抽象結(jié)構(gòu)##

  • 堆內(nèi)存存放所有實例域、靜態(tài)域和數(shù)組元素,堆內(nèi)存在線程之間共享
  • 局部變量、方法定義參數(shù)和異常處理器參數(shù)不會在線程之間共享
  • java線程之間的通信由內(nèi)存模型(JMM)控制,它決定了一個線程對共享變量的寫入何時對另一個線程可見
  • 線程之間的共享變量存儲在主內(nèi)存(Main Memory)中,每個線程都有一個本地變量(local memory),用來存儲讀寫共享變量的副本,涵蓋了緩存、寫緩沖區(qū)、寄存器及其他的硬件和編譯器優(yōu)化

JMM抽象示意圖[1]


JMM抽象示意圖

線程A和線程B通信需要:

  1. 線程A把本地內(nèi)存A中的共享變量副本刷新到主內(nèi)存中去
  2. 線程B去主內(nèi)存中讀取線程A更新的共享變量

參考:[1] http://ifeve.com/java-memory-model-1/

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容