第 5-7 课:Java 中的各种锁和 CAS + 面试题
如果說(shuō)快速理解多線程有什么捷徑的話,那本文介紹的各種鎖無(wú)疑是其中之一,它不但為我們開(kāi)發(fā)多線程程序提供理論支持,還是面試中經(jīng)常被問(wèn)到的核心面試題之一。因此下面就讓我們一起深入地學(xué)習(xí)一下這些鎖吧。
樂(lè)觀鎖和悲觀鎖
悲觀鎖和樂(lè)觀鎖并不是某個(gè)具體的“鎖”而是一種并發(fā)編程的基本概念。樂(lè)觀鎖和悲觀鎖最早出現(xiàn)在數(shù)據(jù)庫(kù)的設(shè)計(jì)當(dāng)中,后來(lái)逐漸被 Java 的并發(fā)包所引入。
悲觀鎖
悲觀鎖認(rèn)為對(duì)于同一個(gè)數(shù)據(jù)的并發(fā)操作,一定是會(huì)發(fā)生修改的,哪怕沒(méi)有修改,也會(huì)認(rèn)為修改。因此對(duì)于同一個(gè)數(shù)據(jù)的并發(fā)操作,悲觀鎖采取加鎖的形式。悲觀地認(rèn)為,不加鎖的并發(fā)操作一定會(huì)出問(wèn)題。
樂(lè)觀鎖
樂(lè)觀鎖正好和悲觀鎖相反,它獲取數(shù)據(jù)的時(shí)候,并不擔(dān)心數(shù)據(jù)被修改,每次獲取數(shù)據(jù)的時(shí)候也不會(huì)加鎖,只是在更新數(shù)據(jù)的時(shí)候,通過(guò)判斷現(xiàn)有的數(shù)據(jù)是否和原數(shù)據(jù)一致來(lái)判斷數(shù)據(jù)是否被其他線程操作,如果沒(méi)被其他線程修改則進(jìn)行數(shù)據(jù)更新,如果被其他線程修改則不進(jìn)行數(shù)據(jù)更新。
公平鎖和非公平鎖
根據(jù)線程獲取鎖的搶占機(jī)制,鎖又可以分為公平鎖和非公平鎖。
公平鎖
公平鎖是指多個(gè)線程按照申請(qǐng)鎖的順序來(lái)獲取鎖。
非公平鎖
非公平鎖是指多個(gè)線程獲取鎖的順序并不是按照申請(qǐng)鎖的順序,有可能后申請(qǐng)的線程比先申請(qǐng)的線程優(yōu)先獲取鎖。
ReentrantLock 提供了公平鎖和非公平鎖的實(shí)現(xiàn)。
- 公平鎖:new ReentrantLock(true)
- 非公平鎖:new ReentrantLock(false)
如果構(gòu)造函數(shù)不傳任何參數(shù)的時(shí)候,默認(rèn)提供的是非公平鎖。
獨(dú)占鎖和共享鎖
根據(jù)鎖能否被多個(gè)線程持有,可以把鎖分為獨(dú)占鎖和共享鎖。
總結(jié)
以上是生活随笔為你收集整理的第 5-7 课:Java 中的各种锁和 CAS + 面试题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 有人说:轻量级锁一定比重量级锁快!我忍不
- 下一篇: Java 200+ 面试题补充② Net