乐观锁和悲观锁的使用场景及应用——Java高并发系列学习笔记
一. 定義
1、樂觀鎖:顧名思義,對每次的數(shù)據(jù)操作都保持樂觀的態(tài)度,不擔(dān)心數(shù)據(jù)會被修改,所以不會對數(shù)據(jù)進(jìn)行上鎖。由于數(shù)據(jù)沒有上鎖,這就存在數(shù)據(jù)會被多人讀寫的情況。所以每次修改數(shù)據(jù)的時(shí)候需要對數(shù)據(jù)進(jìn)行判斷是否被修改過。
2、悲觀鎖:與樂觀鎖相反,對每次的數(shù)據(jù)操作都保存悲觀的態(tài)度,總是擔(dān)心數(shù)據(jù)會被修改,所以在自己操作的時(shí)候會對數(shù)據(jù)上鎖,防止在自己操作的時(shí)候被他人同時(shí)操作導(dǎo)致更新丟失。
二. 使用場景
1、樂觀鎖:由于樂觀鎖的不上鎖特性,所以在性能方面要比悲觀鎖好,比較適合用在DB的讀大于寫的業(yè)務(wù)場景。
2、悲觀鎖:對于每一次數(shù)據(jù)修改都要上鎖,如果在DB讀取需要比較大的情況下有線程在執(zhí)行數(shù)據(jù)修改操作會導(dǎo)致讀操作全部被掛載起來,等修改線程釋放了鎖才能讀到數(shù)據(jù),體驗(yàn)極差。所以比較適合用在DB寫大于讀的情況。
三. 實(shí)現(xiàn)
樂觀鎖兩種常用的實(shí)現(xiàn)方式
第一種是使用版本號或者時(shí)間戳。在表中加個(gè)version或updatetime字段,在每次更新操作時(shí)對此一下該字段,如果一致則更新數(shù)據(jù),數(shù)據(jù)不等則放棄本次修改,根據(jù)實(shí)際業(yè)務(wù)需求做相應(yīng)的處理。
第二種是CAS方式。 即Java中的compareAndSwap。CAS操作涉及到三個(gè)操作數(shù),內(nèi)存值(valueOffSet)、期望值(expect)、更新值(update)。當(dāng)內(nèi)存值與期望值一致時(shí)就會更新數(shù)據(jù),反之不操作。
悲觀鎖三種常用的實(shí)現(xiàn)方式
第一種是數(shù)據(jù)庫實(shí)現(xiàn)方式。 使用數(shù)據(jù)庫的讀鎖、寫鎖、行鎖等實(shí)現(xiàn)進(jìn)程的懸掛阻塞等當(dāng)前操作完成后才能進(jìn)行下一個(gè)操作。
第二種是synchronize的實(shí)現(xiàn)方式。 在Java里面可以使用synchronize實(shí)現(xiàn)悲觀鎖。
第三種是使用封裝JUC包的實(shí)現(xiàn)方式。 在Java中使用LinkedBlockingQueue、ArrayBlockingQueue等JUC的封裝包來實(shí)現(xiàn)悲觀鎖,其根本原理是AQS,而AQS是synchronize的升級版。
總結(jié)
以上是生活随笔為你收集整理的乐观锁和悲观锁的使用场景及应用——Java高并发系列学习笔记的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Leecode31. 下一个排列——Le
- 下一篇: postman根据请求内容生成对应的代码