基礎-兩個關鍵問題
- 線程間通信
線程間通信的機制有兩種:1、共享內存 : 線程之間通過讀寫程序的公共狀態進行隱式通信 2、消息傳遞:線程之間通過發送消息來顯示進行通信,線程間沒有公共狀態
- 線程間同步
同步是指程序中用于控制不同線程間操作發生相對順序的機制。共享內存并發模型中,同步是顯示進行,程序員必須顯示指定方法或代碼間是互斥執行;消息傳遞機制中,同步是隱式進行的
- java開發采用的是共享內存模型,線程間通信是隱式執行的
堆內存與棧內存
- Java的內存分為堆內存與棧內存。堆內存主要存放new 創建的對象和數組;棧內存主要存放一些基本類型的變量和對象(或數組)的引用變量。
- 對象被創建成功后,存放在堆內存里,不能直接訪問,只能通過對象的引用操作該對象
- 如果堆內存中的對象沒有任何變量指向,那么程序將無法再訪問該對象,垃圾回收機制會進行回收,釋放其內存空間
Java內存模型的抽象結構##
- 堆內存存放所有實例域、靜態域和數組元素,堆內存在線程之間共享
- 局部變量、方法定義參數和異常處理器參數不會在線程之間共享
- java線程之間的通信由內存模型(JMM)控制,它決定了一個線程對共享變量的寫入何時對另一個線程可見
- 線程之間的共享變量存儲在主內存(Main Memory)中,每個線程都有一個本地變量(local memory),用來存儲讀寫共享變量的副本,涵蓋了緩存、寫緩沖區、寄存器及其他的硬件和編譯器優化
JMM抽象示意圖[1]
JMM抽象示意圖
線程A和線程B通信需要:
- 線程A把本地內存A中的共享變量副本刷新到主內存中去
- 線程B去主內存中讀取線程A更新的共享變量