一、什么是CAS
CAS(Compare And Swap),即比較并交換。是解決多線程并行情況下使用鎖造成性能損耗的一種機(jī)制,CAS操作包含三個操作數(shù)————內(nèi)存位置(V)、預(yù)期原值(A) 和新值(B)。如果內(nèi)存位置的值與預(yù)期原值相匹配,那么處理器會自動將該位置值更新為新值。否則,處理器不做任何操作。無論哪種情況,它都會在CAS指令之前返回該位置的值。CAS有效地說明了“我認(rèn)為位置V應(yīng)該包含值A(chǔ);如果包含該值,則將B放到這個位置;否則,不要更改該位置,只告訴我這個位置現(xiàn)在的值即可。”
二、什么是AQS
AQS(AbstractQueuedSynchronizer),AQS是JDK下提供的一套用于實現(xiàn)基于FIFO等待隊列的阻塞鎖和相關(guān)的同步器的一個同步框架。這個抽象類被設(shè)計為作為一些可用原子int值來表示狀態(tài)的同步器的基類。