91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解Java多線程樂觀鎖和CAS機制

發布時間:2021-10-08 09:03:24 來源:億速云 閱讀:154 作者:iii 欄目:開發技術

這篇文章主要講解了“如何理解Java多線程樂觀鎖和CAS機制”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何理解Java多線程樂觀鎖和CAS機制”吧!

目錄
  • 一、悲觀鎖和樂觀鎖

    • 1、悲觀鎖

    • 2、樂觀鎖

  • 二、CAS機制

    一、悲觀鎖和樂觀鎖

    1、悲觀鎖

    悲觀鎖是基于一種悲觀的態度類來防止一切數據沖突,它是以一種預防的姿態在修改數據之前把數據鎖住,然后再對數據進行讀寫,在它釋放鎖之前任何人都不能對其數據進行操作,直到前面一個人把鎖釋放后下一個人數據加鎖才可對數據進行加鎖,然后才可以對數據進行操作。synchronized是悲觀鎖,這種線程一旦得到鎖,其他需要鎖的線程就掛起的情況就是悲觀鎖。

    特點:可以完全保證數據的獨占性和正確性,因為每次請求都會先對數據進行加鎖, 然后進行數據操作,最后再解鎖,而加鎖釋放鎖的過程會造成消耗,所以性能不高;

    2、樂觀鎖

    樂觀鎖是對于數據沖突保持一種樂觀態度,操作數據時不會對操作的數據進行加鎖(這使得多個任務可以并行的對數據進行操作),只有到數據提交的時候才通過一種機制來驗證數據是否存在沖突。CAS操作的就是樂觀鎖,每次不加鎖而是假設沒有沖突而去完成某項操作,如果因為沖突失敗就重試,直到成功為止。

    特點:樂觀鎖是一種并發類型的鎖,其本身不對數據進行加鎖通而是通過業務實現鎖的功能,不對數據進行加鎖就意味著允許多個請求同時訪問數據,同時也省掉了對數據加鎖和解鎖的過程,這種方式因為節省了悲觀鎖加鎖的操作,所以可以一定程度的的提高操作的性能,不過在并發非常高的情況下,會導致大量的請求沖突,沖突導致大部分操作無功而返而浪費資源,所以在高并發的場景下,樂觀鎖的性能卻反而不如悲觀鎖。

    二、CAS機制

    CAS機制的全稱是Compare And Swap,翻譯過來就是比較并且交換,CAS機制中有三個變量,內存地址address,舊的預期值oldvalue,要修改的新值newvalue。當進行CAS操作時,首先先檢測和比較內存地址和舊的預期值是否一致,如果一致返回true,否則返回false。可以看下面的代碼能好得理解。

    代碼中AtomicInteger是原子操作類,count.compareAndSet(11,10)就是CAS機制,他是一個原子操作,他先要比較原先的count值是否是11,如果是11的話,就改成10,如果線程1和線程2進入代碼中,但是線程1先觸發了CAS,將count值變10,那么線程2執行到CAS機制的時候發現count值已經不等于10了,那么這個compareAndSet函數會返回false,進入else中繼續run()。線程1休眠5s以后,將count值修改成11以后,線程2再次進入compareAndSet函數發現count值變成了11,那么就把值修改成10了,并且返回true值。由此實現了樂觀鎖。

    public class AtomiIntegerTestimplements Runnable {
        private AtomicInteger count = new AtomicInteger(11);
    
        public static void main(String[] args) {
            AtomiIntegerTest ast = new AtomiIntegerTest();
            Thread thread1 = new Thread(ast);
            Thread thread = new Thread(ast);
            thread1.start();
            thread.start();
        }
        @Override
        public void run() {
            System.out.println("thread:"+Thread.currentThread().getName()+";count:"+count.get());
            if (count.compareAndSet(11,10)){
                System.out.println(Thread.currentThread().getName()+";修改成功"+count.get());
                try {
                    Thread.sleep(5000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                count.set(11);
            }else{
                System.out.println("重試機制thread:"+Thread.currentThread().getName()+";flag:"+count.get());
                try {
                    Thread.sleep(500);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                run();
            }
        }
    }

    如何理解Java多線程樂觀鎖和CAS機制

    感謝各位的閱讀,以上就是“如何理解Java多線程樂觀鎖和CAS機制”的內容了,經過本文的學習后,相信大家對如何理解Java多線程樂觀鎖和CAS機制這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    绵阳市| 河南省| 四子王旗| 贵港市| 绥阳县| 宁德市| 仙桃市| 库伦旗| 苗栗县| 峨眉山市| 平远县| 赫章县| 镇平县| 五台县| 信阳市| 元江| 安泽县| 渭南市| 邮箱| 濮阳县| 古浪县| 鄂托克前旗| 福海县| 扶沟县| 红安县| 申扎县| 迁安市| 德化县| 全州县| 婺源县| 安仁县| 九江市| 东宁县| 巴彦淖尔市| 蒙城县| 通化市| 诸城市| 南陵县| 达日县| 益阳市| 封开县|