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

溫馨提示×

溫馨提示×

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

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

JUC中的Lock鎖與synchronized同步代碼塊問題怎么解決

發布時間:2022-04-11 13:55:45 來源:億速云 閱讀:205 作者:iii 欄目:開發技術

這篇文章主要介紹“JUC中的Lock鎖與synchronized同步代碼塊問題怎么解決”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“JUC中的Lock鎖與synchronized同步代碼塊問題怎么解決”文章能幫助大家解決問題。

一、Lock鎖

  • ReentrantLock類: 可重用鎖(公平鎖|非公平鎖)

  • ReentrantReadWriteLock.ReadLock:讀鎖

  • ReentrantReadWriteLock.WriteLock:寫鎖

二、鎖的底層

鎖的底層有公平鎖和非公平鎖。其中:

  • 公平鎖 :十分公平,不能插隊。

  • 非公平鎖 :十分不公平,可以插隊。(默認非公平鎖)

三、案例

案例一:傳統的synchronized實現

/**
 * synchronized 同步代碼塊保證售票線程安全
 *
 * @Author JUNSHI
 * @Create 2022-04-10 22:46
 */
public class SaleTicketDemo01 {
    public static void main(String[] args) {
        Ticket ticket = new Ticket();
        new Thread(()->{
            for (int i = 0; i < 60; i++) {
                ticket.sale();
            }
        },"AA").start();
        },"BB").start();
        new Thread(() -> {
        }, "CC").start();
    }
    static class Ticket{
        // 50張飄票
        private int num = 50;
        // 售票 synchronized(同步代碼塊) 本質: 隊列,鎖
        public synchronized void sale(){
            if (num > 0){
                System.out.println(Thread.currentThread().getName()+"賣出了"+(num--)+"票,剩余:"+num);
        }
}

案例二:Lock鎖的實現

/**
 * Lock 加鎖保證售票線程安全
 *
 * @Author JUNSHI
 * @Create 2022-04-10 22:46
 */
public class SaleTicketDemo02 {

    public static void main(String[] args) {
        Ticket2 ticket = new Ticket2();
        new Thread(()->{ for (int i = 0; i < 60; i++) ticket.sale(); },"AA").start();
        new Thread(()->{ for (int i = 0; i < 60; i++) ticket.sale(); },"BB").start();
        new Thread(()->{ for (int i = 0; i < 60; i++) ticket.sale(); },"CC").start();
    }

    static class Ticket2{
        // 50張飄票
        private int num = 50;

        // 加鎖三部曲
        // 1、 創建鎖 => new ReentrantLock();
        // 2、 加鎖 =>  lock.lock();
        // 3、 釋放鎖 => lock.unlock();
        public void sale(){
            // 可重入鎖  默認:非公平鎖:十分不公平,可以插隊。(默認非公平鎖)
            Lock lock = new ReentrantLock();
            // 加鎖
            lock.lock();
            try {
                // 執行業務
                if (num > 0){
                    System.out.println(Thread.currentThread().getName()+"賣出了"+(num--)+"票,剩余:"+num);
                }
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                // 解鎖
                lock.unlock();
            }
        }
    }
}

四、Lock鎖和synchronized的區別

  1. snchronized是內置Java關鍵字;Lock是一個Java類。

  2. synchronized 無法判斷獲取鎖的狀態;Lock可以判斷是否獲取到了鎖。(boolean b = lock.tryLock();)

  3. synchronized會自動釋放鎖Lock必須要手動釋放鎖,如果不釋放鎖,死鎖

  4. synchronized線程1獲得鎖阻塞時,線程2會一直等待下去;Lock鎖線程1獲得鎖阻塞時,線程2等待足夠長的時間后中斷等待,去做其他的事。

  5. synchronized可重入鎖:不可以中斷的,非公平;Lock可重入鎖:可以判斷鎖,非公平(可以自己設置)。

  6. lock.lockInterruptibly();方法:當兩個線程同時通過該方法想獲取某個鎖時,假若此時線程A獲取到了鎖,而線程B只有在等待,那么對線程B調用threadB.interrupt()方法能夠中斷線程B的等待過程。

  7. synchronized適合鎖少量的代碼同步問題; Lock適合鎖大量的同步代碼。

關于“JUC中的Lock鎖與synchronized同步代碼塊問題怎么解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

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

AI

邢台市| 泾源县| 盐城市| 许昌市| 安阳县| 建德市| 安国市| 汉阴县| 宁陵县| 象山县| 隆安县| 屯留县| 甘洛县| 横峰县| 峨眉山市| 盱眙县| 尉氏县| 南宁市| 新晃| 清苑县| 图们市| 阜城县| 南平市| 富民县| 搜索| 博客| 滨海县| 富裕县| 正定县| 台南县| 雷山县| 云梦县| 综艺| 叙永县| 双柏县| 偃师市| 芜湖县| 平遥县| 开阳县| 宝丰县| 武隆县|