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