Java并發(fā)線程如何阻塞和喚醒?
Java并發(fā)線程的阻塞和喚醒可分幾類:
1. synchronize基于JVM的對象頭來實(shí)現(xiàn),多線程爭搶同一個臨界資源時根據(jù)不同的鎖機(jī)制(自旋鎖、輕/重量級鎖)來進(jìn)行阻塞和喚醒。
2. notify/wait,yeild等基礎(chǔ)機(jī)制這里暫時略過,大致實(shí)現(xiàn)原理是基于對象的同步隊列和后面的AQS很像。
3. 并發(fā)組件的基礎(chǔ)AQS重點(diǎn)說下AQS(AbstractQueuedSynchronizer),
因?yàn)檫@是jdk并發(fā)包實(shí)現(xiàn)的基礎(chǔ)(如Lock、BlockingQueue、CountdownLatch等)。
Aqs基本由一個volatile變量state和一個等待隊列來實(shí)現(xiàn),搶鎖時先CAS修改state,失敗以后就放到等待隊列里,并通過LockSupport將線程掛起。
當(dāng)鎖的擁有者釋放鎖時會通過LockSupport喚醒等待隊列的后續(xù)節(jié)點(diǎn),讓它再次去嘗試搶鎖(CAS修改state),如此反復(fù)。
掌握AQS的原理對理解jdk里很多并發(fā)組件非常有幫助。
上一篇golang比java好
下一篇在大公司做JAVA項目