Java并發學習(一):Java內存模型

基礎-兩個關鍵問題

  1. 線程間通信

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

  1. 線程間同步

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

  1. java開發采用的是共享內存模型,線程間通信是隱式執行的

堆內存與棧內存

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

Java內存模型的抽象結構##

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

JMM抽象示意圖[1]


JMM抽象示意圖

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

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

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

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容