文章詳情頁
java - Cas操作會加鎖嗎
瀏覽:116日期:2024-01-12 09:39:59
問題描述
問題:(1)不需要cas操作來加鎖和解鎖,這個怎么理解??cas操作不是如果比較不成功那么就一直嘗試嗎?和加鎖有什么關(guān)系??這個該如何理解
問題解答
回答1:compare and swap操作不一定不需要鎖,看平臺,但是大多數(shù)平臺都是支持無鎖cas的。最簡單的鎖是通過test and set實現(xiàn)的自旋鎖,當(dāng)然通過cas也可以實現(xiàn)。
自旋鎖在上鎖失敗時的確會不斷嘗試,耗盡cpu資源。如
while (flag.test_and_set()) { /* yield; */ } // 上鎖flag.clear(); // 解鎖
系統(tǒng)接口提供的鎖,上鎖失敗時一般會掛起線程,類似
while (flag.test_and_set()) { flag.wait_for_unlock_signal(); } // 上鎖
這里的wait_for_unlock_signal()是個假想函數(shù)。但是上鎖依然依賴類似cas的原子操作。也就是說,現(xiàn)在鎖都是通過一些基本的原子操作來實現(xiàn)的,如test and set和compare and swap。
標(biāo)簽:
java
相關(guān)文章:
1. javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?2. showpassword里的this 是什么意思?代表哪個元素3. mysql scripts提示 /usr/bin/perl: bad interpreter4. css3 - css怎么實現(xiàn)圖片環(huán)繞的效果5. html - vue項目中用到了elementUI問題6. 對mysql某個字段監(jiān)控的功能7. java - spring boot @Autowired8. JavaScript事件9. css3 - border-bottom 的長度可否超過盒子的寬度呢?實現(xiàn)如下圖效果。(我的書下面的線)10. mysql優(yōu)化 - mysql EXPLAIN之后怎么看結(jié)果進(jìn)行優(yōu)化 ?
排行榜

熱門標(biāo)簽