欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中的synchronized有幾種加鎖方式(實(shí)例詳解)

 更新時(shí)間:2024年05月22日 09:21:11   作者:TS86  
在Java中,synchronized關(guān)鍵字提供了內(nèi)置的支持來(lái)實(shí)現(xiàn)同步訪問(wèn)共享資源,以避免并發(fā)問(wèn)題,這篇文章主要介紹了java的synchronized有幾種加鎖方式,需要的朋友可以參考下

在Java中,synchronized關(guān)鍵字提供了內(nèi)置的支持來(lái)實(shí)現(xiàn)同步訪問(wèn)共享資源,以避免并發(fā)問(wèn)題。synchronized主要有三種加鎖方式:

1.同步實(shí)例方法

當(dāng)一個(gè)實(shí)例方法被聲明為synchronized時(shí),該方法將同一時(shí)間只能被一個(gè)線程訪問(wèn)。鎖是當(dāng)前對(duì)象實(shí)例(即this)。

public class SynchronizedInstanceMethod {  
    public synchronized void doSomething() {  
        // 同步代碼塊  
        // 同一時(shí)間只能有一個(gè)線程執(zhí)行這里的代碼  
    }  
    public static void main(String[] args) {  
        SynchronizedInstanceMethod obj = new SynchronizedInstanceMethod();  
        // 創(chuàng)建多個(gè)線程訪問(wèn)obj的doSomething方法,它們將串行執(zhí)行  
        // ...  
    }  
}

當(dāng)我們創(chuàng)建了兩個(gè)線程來(lái)并發(fā)地增加計(jì)數(shù)器,由于我們使用了synchronized,因此計(jì)數(shù)器的增加線程是安全的,即使兩個(gè)線程都在嘗試修改同一個(gè)共享變量。在同步實(shí)例方法中,鎖分別是實(shí)例對(duì)象和類對(duì)象。

public class SynchronizedInstanceMethodExample {  
    private int count = 0;  
    // 同步實(shí)例方法,鎖定的是當(dāng)前對(duì)象的實(shí)例(this)  
    public synchronized void increment() {  
        count++;  
        System.out.println(Thread.currentThread().getName() + " incremented count to " + count);  
    }  
    public static void main(String[] args) {  
        final SynchronizedInstanceMethodExample example = new SynchronizedInstanceMethodExample();  
        // 創(chuàng)建兩個(gè)線程來(lái)增加計(jì)數(shù)器  
        Thread thread1 = new Thread(() -> {  
            for (int i = 0; i < 1000; i++) {  
                example.increment();  
            }  
        }, "Thread-1");  
        Thread thread2 = new Thread(() -> {  
            for (int i = 0; i < 1000; i++) {  
                example.increment();  
            }  
        }, "Thread-2");  
        // 啟動(dòng)線程  
        thread1.start();  
        thread2.start();  
        // 等待線程完成  
        try {  
            thread1.join();  
            thread2.join();  
        } catch (InterruptedException e) {  
            e.printStackTrace();  
        }  
        // 輸出最終計(jì)數(shù)  
        System.out.println("Final count: " + example.count);  
    }  
}

2.同步靜態(tài)方法

當(dāng)一個(gè)靜態(tài)方法被聲明為synchronized時(shí),該方法將同一時(shí)間只能被一個(gè)線程訪問(wèn)。鎖是Class對(duì)象,而不是實(shí)例對(duì)象。

public class SynchronizedStaticMethod {  
    public static synchronized void doSomethingStatic() {  
        // 同步代碼塊  
        // 同一時(shí)間只能有一個(gè)線程執(zhí)行這里的代碼  
    }  
    public static void main(String[] args) {  
        // 創(chuàng)建多個(gè)線程訪問(wèn)SynchronizedStaticMethod的doSomethingStatic方法,它們將串行執(zhí)行  
        // ...  
    }  
}

當(dāng)我們創(chuàng)建了兩個(gè)線程來(lái)并發(fā)地增加計(jì)數(shù)器,由于我們使用了synchronized,因此計(jì)數(shù)器的增加線程是安全的,即使兩個(gè)線程都在嘗試修改同一個(gè)共享變量。在同步靜態(tài)方法中,鎖分別也是實(shí)例對(duì)象和類對(duì)象。

public class SynchronizedStaticMethodExample {  
    private static int count = 0;  
    // 同步靜態(tài)方法,鎖定的是當(dāng)前對(duì)象的類(Class)對(duì)象  
    public static synchronized void increment() {  
        count++;  
        System.out.println(Thread.currentThread().getName() + " incremented static count to " + count);  
    }  
    public static void main(String[] args) {  
        // 創(chuàng)建兩個(gè)線程來(lái)增加計(jì)數(shù)器  
        Thread thread1 = new Thread(() -> {  
            for (int i = 0; i < 1000; i++) {  
                increment();  
            }  
        }, "Thread-1");  
        Thread thread2 = new Thread(() -> {  
            for (int i = 0; i < 1000; i++) {  
                increment();  
            }  
        }, "Thread-2");  
        // 啟動(dòng)線程...  
        // 等待線程完成...  
        // 輸出最終計(jì)數(shù)...  
        // (與上面的例子類似,但省略了重復(fù)的代碼)  
    }  
}

3.同步代碼塊

我們可以使用synchronized關(guān)鍵字來(lái)定義一個(gè)代碼塊,而不是整個(gè)方法。在這種情況下,你可以指定要獲取的鎖對(duì)象。這提供了更細(xì)粒度的同步控制。

public class SynchronizedBlock {  
    private final Object lock = new Object(); // 用于同步的鎖對(duì)象  
    public void doSomething() {  
        synchronized (lock) {  
            // 同步代碼塊  
            // 同一時(shí)間只有一個(gè)線程能夠執(zhí)行這里的代碼  
        }  
        // 這里的代碼不受同步代碼塊的約束  
    }  
    public static void main(String[] args) {  
        SynchronizedBlock obj = new SynchronizedBlock();  
        // 創(chuàng)建多個(gè)線程訪問(wèn)obj的doSomething方法,但只有在synchronized塊中的代碼將串行執(zhí)行  
        // ...  
    }  
}

在上面的SynchronizedBlock類中,我們創(chuàng)建了一個(gè)私有的Object實(shí)例lock作為鎖對(duì)象。當(dāng)線程進(jìn)入synchronized (lock)塊時(shí),它會(huì)嘗試獲取lock對(duì)象的鎖。如果鎖已經(jīng)被其他線程持有,那么該線程將被阻塞,直到鎖被釋放。

當(dāng)我們創(chuàng)建了兩個(gè)線程來(lái)并發(fā)地增加計(jì)數(shù)器,同步代碼塊的例子中,我們顯式地指定了一個(gè)對(duì)象作為鎖。

public class SynchronizedBlockExample {  
    private final Object lock = new Object(); // 用于同步的鎖對(duì)象  
    private int count = 0;  
    // 同步代碼塊,指定了鎖對(duì)象  
    public void increment() {  
        synchronized (lock) {  
            count++;  
            System.out.println(Thread.currentThread().getName() + " incremented count to " + count);  
        }  
    }  
    public static void main(String[] args) {  
        // 類似于上面的例子,但使用SynchronizedBlockExample的increment方法  
        // ...(省略了重復(fù)的代碼)  
    }  
}

注意:使用synchronized時(shí)應(yīng)該盡量避免在持有鎖的情況下執(zhí)行耗時(shí)的操作,因?yàn)檫@會(huì)導(dǎo)致其他等待鎖的線程長(zhǎng)時(shí)間阻塞。同時(shí),過(guò)度使用synchronized可能會(huì)導(dǎo)致性能下降,因?yàn)樗鼤?huì)引入線程間的競(jìng)爭(zhēng)和可能的上下文切換。在設(shè)計(jì)并發(fā)程序時(shí),應(yīng)該仔細(xì)考慮同步的粒度,并可能使用其他并發(fā)工具(如ReentrantLock、Semaphore、CountDownLatch等)來(lái)提供更細(xì)粒度的控制。

到此這篇關(guān)于java的synchronized有幾種加鎖方式的文章就介紹到這了,更多相關(guān)java synchronized加鎖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java數(shù)學(xué)工具類MathUtil詳解

    Java數(shù)學(xué)工具類MathUtil詳解

    這篇文章主要為大家詳細(xì)介紹了Java數(shù)學(xué)工具類MathUtil的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • Java中的String對(duì)象數(shù)據(jù)類型全面解析

    Java中的String對(duì)象數(shù)據(jù)類型全面解析

    首先String不屬于8種基本數(shù)據(jù)類型,String是一個(gè)對(duì)象,因?yàn)閷?duì)象的默認(rèn)值是null,所以String的默認(rèn)值也是null;但它又是一種特殊的對(duì)象,有其它對(duì)象沒(méi)有的一些特性
    2012-11-11
  • JAVA中讀取文件(二進(jìn)制,字符)內(nèi)容的幾種方法總結(jié)

    JAVA中讀取文件(二進(jìn)制,字符)內(nèi)容的幾種方法總結(jié)

    本篇文章主要介紹了JAVA中讀取文件(二進(jìn)制,字符)內(nèi)容的方法總結(jié),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02
  • Guava - 并行編程Futures詳解

    Guava - 并行編程Futures詳解

    這篇文章主要介紹了Guava - 并行編程Futures詳解方法的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • Java超詳細(xì)梳理異常處理機(jī)制

    Java超詳細(xì)梳理異常處理機(jī)制

    異常就是不正常,比如當(dāng)我們身體出現(xiàn)了異常我們會(huì)根據(jù)身體情況選擇喝開(kāi)水、吃藥、看病、等?異常處理方法。?java異常處理機(jī)制是我們java語(yǔ)言使用異常處理機(jī)制為程序提供了錯(cuò)誤處理的能力,程序出現(xiàn)的錯(cuò)誤,程序可以安全的退出,以保證程序正常的運(yùn)行等
    2022-04-04
  • Java圖形化界面設(shè)計(jì)之容器(JFrame)詳解

    Java圖形化界面設(shè)計(jì)之容器(JFrame)詳解

    這篇文章主要介紹了Java圖形化界面設(shè)計(jì)之容器(JFrame)詳解,條理清晰,依次介紹了Java基本類(JFC),AWT和Swing的區(qū)別,Swing基本框架,圖形化設(shè)計(jì)步驟以及組件容器的使用等相關(guān)內(nèi)容,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • 詳解Java編程中super關(guān)鍵字的用法

    詳解Java編程中super關(guān)鍵字的用法

    這篇文章主要介紹了Java編程中this與super關(guān)鍵字的用法,包括從內(nèi)存結(jié)構(gòu)方面分析super的作用域,需要的朋友可以參考下
    2015-10-10
  • SpringBoot RESTful風(fēng)格入門講解

    SpringBoot RESTful風(fēng)格入門講解

    RESTful是一種web軟件風(fēng)格,它不是標(biāo)準(zhǔn)也不是協(xié)議,它不一定要采用,只是一種風(fēng)格,它倡導(dǎo)的是一個(gè)資源定位(url)及資源操作的風(fēng)格,這篇文章主要介紹了SpringBoot使用RESTful接口
    2022-11-11
  • Java?八種基本數(shù)據(jù)類型最新整理

    Java?八種基本數(shù)據(jù)類型最新整理

    這篇文章給大家分享Java八種基本數(shù)據(jù)類型,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2025-06-06
  • 排查Java應(yīng)用內(nèi)存泄漏問(wèn)題的步驟

    排查Java應(yīng)用內(nèi)存泄漏問(wèn)題的步驟

    這篇文章主要介紹了排查Java應(yīng)用內(nèi)存泄漏問(wèn)題的步驟,幫助大家更好的理解和學(xué)習(xí)Java,感興趣的朋友可以了解下
    2020-11-11

最新評(píng)論