基礎(chǔ)-兩個關(guān)鍵問題
- 線程間通信
線程間通信的機制有兩種:1、共享內(nèi)存 : 線程之間通過讀寫程序的公共狀態(tài)進行隱式通信 2、消息傳遞:線程之間通過發(fā)送消息來顯示進行通信,線程間沒有公共狀態(tài)
- 線程間同步
同步是指程序中用于控制不同線程間操作發(fā)生相對順序的機制。共享內(nèi)存并發(fā)模型中,同步是顯示進行,程序員必須顯示指定方法或代碼間是互斥執(zhí)行;消息傳遞機制中,同步是隱式進行的
- 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通信需要:
- 線程A把本地內(nèi)存A中的共享變量副本刷新到主內(nèi)存中去
- 線程B去主內(nèi)存中讀取線程A更新的共享變量