国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Synchronize和ReentrantLock區(qū)別

FuisonDesign / 1779人閱讀

摘要:的鎖是非公平鎖,默認(rèn)情況下也是非公平鎖,但可以通過帶布爾值的構(gòu)造函數(shù)要求使用公平鎖。有序性,是保證線程內(nèi)串行語義,避免指令重排等。公平性是減少線程饑餓個(gè)別線程長期等待鎖,但始終無法獲取情況發(fā)生的一個(gè)辦法。

目錄介紹

1.Synchronize和ReentrantLock區(qū)別

1.1 相似點(diǎn)

1.2 區(qū)別

1.3 什么是線程安全問題?如何理解

1.4 線程安全需要保證幾個(gè)基本特性

2.Synchronize在編譯時(shí)如何實(shí)現(xiàn)鎖機(jī)制

3.ReentrantLock使用方法

4.ReentrantLock鎖機(jī)制測(cè)試案例分析

4.1 代碼案例分析

4.2 什么時(shí)候選擇用ReentrantLock

4.3 公平鎖和非公平鎖有何區(qū)別

5.問答測(cè)試題

5.1 ReentrantLock和synchronized使用分析

好消息

博客筆記大匯總【16年3月到至今】,包括Java基礎(chǔ)及深入知識(shí)點(diǎn),Android技術(shù)博客,Python學(xué)習(xí)筆記等等,還包括平時(shí)開發(fā)中遇到的bug匯總,當(dāng)然也在工作之余收集了大量的面試題,長期更新維護(hù)并且修正,持續(xù)完善……開源的文件是markdown格式的!同時(shí)也開源了生活博客,從12年起,積累共計(jì)47篇[近20萬字],轉(zhuǎn)載請(qǐng)注明出處,謝謝!

鏈接地址:https://github.com/yangchong2...

如果覺得好,可以star一下,謝謝!當(dāng)然也歡迎提出建議,萬事起于忽微,量變引起質(zhì)變!

關(guān)于鎖機(jī)制文章

01.Synchronize深入解析

Synchronize深入解析,sychonized method 和 synchonized代碼塊的效率問題

02.Synchronize和ReentrantLock區(qū)別

Synchronize和ReentrantLock區(qū)別,Synchronize在編譯時(shí)如何實(shí)現(xiàn)鎖機(jī)制,ReentrantLock鎖機(jī)制測(cè)試案例分析,公平鎖和非公平鎖有何區(qū)別等等

03.死鎖的發(fā)生,定位與修復(fù)

死鎖的概念和產(chǎn)生死鎖的根本原因是什么?死鎖的預(yù)防策略中資源有序分配策略是什么。死鎖發(fā)生的場(chǎng)景,死鎖的危害,出現(xiàn)死鎖需要滿足條件分析,如何預(yù)防死鎖,如何定位死鎖,以及死鎖修復(fù)方案分析等等

1.Synchronize和ReentrantLock區(qū)別 1.1 相似點(diǎn):

這兩種同步方式有很多相似之處,它們都是加鎖方式同步,而且都是阻塞式的同步,也就是說當(dāng)如果一個(gè)線程獲得了對(duì)象鎖,進(jìn)入了同步塊,其他訪問該同步塊的線程都必須阻塞在同步塊外面等待,而進(jìn)行線程阻塞和喚醒的代價(jià)是比較高的(操作系統(tǒng)需要在用戶態(tài)與內(nèi)核態(tài)之間來回切換,代價(jià)很高,不過可以通過對(duì)鎖優(yōu)化進(jìn)行改善)。

1.2 區(qū)別:
1.2.1 API層面

這兩種方式最大區(qū)別就是對(duì)于Synchronized來說,它是java語言的關(guān)鍵字,是原生語法層面的互斥,需要jvm實(shí)現(xiàn)。而ReentrantLock它是JDK 1.5之后提供的API層面的互斥鎖,需要lock()和unlock()方法配合try/finally語句塊來完成。

synchronized既可以修飾方法,也可以修飾代碼塊。

//synchronized修飾一個(gè)方法時(shí),這個(gè)方法叫同步方法。
public synchronized void test() {
//方法體``

}

synchronized(Object) {
//括號(hào)中表示需要鎖的對(duì)象.
//線程執(zhí)行的時(shí)候會(huì)對(duì)Object上鎖
}

ReentrantLock使用

private ReentrantLock lock = new ReentrantLock();
public void run() {
    lock.lock();
    try{
        for(int i=0;i<5;i++){
            System.out.println(Thread.currentThread().getName()+":"+i);
        }
    }finally{
        lock.unlock();
    }
}

1.2.2 等待可中斷

等待可中斷是指當(dāng)持有鎖的線程長期不釋放鎖的時(shí)候,正在等待的線程可以選擇放棄等待,改為處理其他事情。可等待特性對(duì)處理執(zhí)行時(shí)間非常長的同步快很有幫助。

具體來說,假如業(yè)務(wù)代碼中有兩個(gè)線程,Thread1 Thread2。假設(shè) Thread1 獲取了對(duì)象object的鎖,Thread2將等待Thread1釋放object的鎖。

使用synchronized。如果Thread1不釋放,Thread2將一直等待,不能被中斷。synchronized也可以說是Java提供的原子性內(nèi)置鎖機(jī)制。內(nèi)部鎖扮演了互斥鎖(mutual exclusion lock ,mutex)的角色,一個(gè)線程引用鎖的時(shí)候,別的線程阻塞等待。

使用ReentrantLock。如果Thread1不釋放,Thread2等待了很長時(shí)間以后,可以中斷等待,轉(zhuǎn)而去做別的事情。

1.2.3 公平鎖

公平鎖是指多個(gè)線程在等待同一個(gè)鎖時(shí),必須按照申請(qǐng)的時(shí)間順序來依次獲得鎖;而非公平鎖則不能保證這一點(diǎn)。非公平鎖在鎖被釋放時(shí),任何一個(gè)等待鎖的線程都有機(jī)會(huì)獲得鎖。

synchronized的鎖是非公平鎖,ReentrantLock默認(rèn)情況下也是非公平鎖,但可以通過帶布爾值的構(gòu)造函數(shù)要求使用公平鎖。

ReentrantLock 構(gòu)造器的一個(gè)參數(shù)是boolean值,它允許您選擇想要一個(gè)公平(fair)鎖,還是一個(gè)不公平(unfair)鎖。公平鎖:使線程按照請(qǐng)求鎖的順序依次獲得鎖, 但是有成本;不公平鎖:則允許討價(jià)還價(jià)

那么如何用代碼設(shè)置公平鎖呢?如下所示

1.2.4 鎖綁定多個(gè)條件

ReentrantLock可以同時(shí)綁定多個(gè)Condition對(duì)象,只需多次調(diào)用newCondition方法即可。

synchronized中,鎖對(duì)象的wait()和notify()或notifyAll()方法可以實(shí)現(xiàn)一個(gè)隱含的條件。但如果要和多于一個(gè)的條件關(guān)聯(lián)的時(shí)候,就不得不額外添加一個(gè)鎖。

1.3 什么是線程安全問題?如何理解

如果你的代碼所在的進(jìn)程中有多個(gè)線程在同時(shí)運(yùn)行,而這些線程可能會(huì)同時(shí)運(yùn)行這段代碼。如果每次運(yùn)行結(jié)果和單線程運(yùn)行的結(jié)果是一樣的,而且其他的變量的值也和預(yù)期的是一樣的,就是線程安全的,或者說:一個(gè)類或者程序所提供的接口對(duì)于線程來說是原子操作或者多個(gè)線程之間的切換不會(huì)導(dǎo)致該接口的執(zhí)行結(jié)果存在二義性,也就是說我們不用考慮同步的問題 。

1.4 線程安全需要保證幾個(gè)基本特性

1、原子性,簡(jiǎn)單說就是相關(guān)操作不會(huì)中途被其他線程干擾,一般通過同步機(jī)制實(shí)現(xiàn)。

2、可見性,是一個(gè)線程修改了某個(gè)共享變量,其狀態(tài)能夠立即被其他線程知曉,通常被解釋為將線程本地狀態(tài)反映到主內(nèi)存上,volatile 就是負(fù)責(zé)保證可見性的。

3、有序性,是保證線程內(nèi)串行語義,避免指令重排等。

2.Synchronize在編譯時(shí)如何實(shí)現(xiàn)鎖機(jī)制

Synchronized進(jìn)過編譯,會(huì)在同步塊的前后分別形成monitorenter和monitorexit這個(gè)兩個(gè)字節(jié)碼指令。在執(zhí)行monitorenter指令時(shí),首先要嘗試獲取對(duì)象鎖。如果這個(gè)對(duì)象沒被鎖定,或者當(dāng)前線程已經(jīng)擁有了那個(gè)對(duì)象鎖,把鎖的計(jì)算器加1,相應(yīng)的,在執(zhí)行monitorexit指令時(shí)會(huì)將鎖計(jì)算器就減1,當(dāng)計(jì)算器為0時(shí),鎖就被釋放了。如果獲取對(duì)象鎖失敗,那當(dāng)前線程就要阻塞,直到對(duì)象鎖被另一個(gè)線程釋放為止。

3.ReentrantLock使用方法

ReentrantLock是java.util.concurrent包下提供的一套互斥鎖,相比Synchronized,ReentrantLock類提供了一些高級(jí)功能,主要有以下3項(xiàng):

1.等待可中斷,持有鎖的線程長期不釋放的時(shí)候,正在等待的線程可以選擇放棄等待,這相當(dāng)于Synchronized來說可以避免出現(xiàn)死鎖的情況。

2.公平鎖,多個(gè)線程等待同一個(gè)鎖時(shí),必須按照申請(qǐng)鎖的時(shí)間順序獲得鎖,Synchronized鎖非公平鎖,ReentrantLock默認(rèn)的構(gòu)造函數(shù)是創(chuàng)建的非公平鎖,可以通過參數(shù)true設(shè)為公平鎖,但公平鎖表現(xiàn)的性能不是很好。

3.鎖綁定多個(gè)條件,一個(gè)ReentrantLock對(duì)象可以同時(shí)綁定對(duì)個(gè)對(duì)象。

使用方法代碼如下

private ReentrantLock lock = new ReentrantLock();
public void run() {
    lock.lock();
    try{
        for(int i=0;i<5;i++){
            System.out.println(Thread.currentThread().getName()+":"+i);
        }
    }finally{
        lock.unlock();
    }
}

注意問題:為保證鎖釋放,每一個(gè) lock() 動(dòng)作,建議都立即對(duì)應(yīng)一都立即對(duì)應(yīng)一個(gè) try-catch-finally

4.ReentrantLock鎖機(jī)制測(cè)試案例分析 4.1 代碼案例分析

代碼如下所示

private void test2() {
    Runnable t1 = new MyThread();
    new Thread(t1,"t1").start();
    new Thread(t1,"t2").start();
}

class MyThread implements Runnable {
    private ReentrantLock lock = new ReentrantLock();
    public void run() {
        lock.lock();
        try{
            for(int i=0;i<5;i++){
                System.out.println(Thread.currentThread().getName()+":"+i);
            }
        }finally{
            lock.unlock();
        }
    }
}

//打印值如下所示
10-17 17:06:59.222 6531-6846/com.yc.cn.ycbaseadapter I/System.out: t1:0
10-17 17:06:59.222 6531-6846/com.yc.cn.ycbaseadapter I/System.out: t1:1
10-17 17:06:59.222 6531-6846/com.yc.cn.ycbaseadapter I/System.out: t1:2
10-17 17:06:59.222 6531-6846/com.yc.cn.ycbaseadapter I/System.out: t1:3
10-17 17:06:59.222 6531-6846/com.yc.cn.ycbaseadapter I/System.out: t1:4
10-17 17:06:59.224 6531-6847/com.yc.cn.ycbaseadapter I/System.out: t2:0
10-17 17:06:59.225 6531-6847/com.yc.cn.ycbaseadapter I/System.out: t2:1
10-17 17:06:59.225 6531-6847/com.yc.cn.ycbaseadapter I/System.out: t2:2
10-17 17:06:59.225 6531-6847/com.yc.cn.ycbaseadapter I/System.out: t2:3
10-17 17:06:59.225 6531-6847/com.yc.cn.ycbaseadapter I/System.out: t2:4

4.2 什么時(shí)候選擇用ReentrantLock

適用場(chǎng)景:時(shí)間鎖等候、可中斷鎖等候、無塊結(jié)構(gòu)鎖、多個(gè)條件變量或者鎖投票

在確實(shí)需要一些 synchronized所沒有的特性的時(shí)候,比如時(shí)間鎖等候、可中斷鎖等候、無塊結(jié)構(gòu)鎖、多個(gè)條件變量或者鎖投票。 ReentrantLock 還具有可伸縮性的好處,應(yīng)當(dāng)在高度爭(zhēng)用的情況下使用它,但是請(qǐng)記住,大多數(shù) synchronized 塊幾乎從來沒有出現(xiàn)過爭(zhēng)用,所以可以把高度爭(zhēng)用放在一邊。我建議用 synchronized 開發(fā),直到確實(shí)證明 synchronized 不合適,而不要僅僅是假設(shè)如果使用 ReentrantLock “性能會(huì)更好”。請(qǐng)記住,這些是供高級(jí)用戶使用的高級(jí)工具。(而且,真正的高級(jí)用戶喜歡選擇能夠找到的最簡(jiǎn)單工具,直到他們認(rèn)為簡(jiǎn)單的工具不適用為止。)。一如既往,首先要把事情做好,然后再考慮是不是有必要做得更快。

使用場(chǎng)景代碼展示【摘自ThreadPoolExecutor類,這個(gè)類中很多地方用到了這個(gè)鎖。自己可以查看】:

/**
 * Rolls back the worker thread creation.
 * - removes worker from workers, if present
 * - decrements worker count
 * - rechecks for termination, in case the existence of this

 */
private void addWorkerFailed(Worker w) {
    final ReentrantLock mainLock = this.mainLock;
    mainLock.lock();
    try {
        if (w != null)
            workers.remove(w);
        decrementWorkerCount();
        tryTerminate();
    } finally {
        mainLock.unlock();
    }
}
```
4.3 公平鎖和非公平鎖有何區(qū)別

公平性是指在競(jìng)爭(zhēng)場(chǎng)景中,當(dāng)公平性為真時(shí),會(huì)傾向于將鎖賦予等待時(shí)間最久的線程。公平性是減少線程“饑餓”(個(gè)別線程長期等待鎖,但始終無法獲取)情況發(fā)生的一個(gè)辦法。

1、公平鎖能保證:老的線程排隊(duì)使用鎖,新線程仍然排隊(duì)使用鎖。

2、非公平鎖保證:老的線程排隊(duì)使用鎖;但是無法保證新線程搶占已經(jīng)在排隊(duì)的線程的鎖。

看下面代碼案例所示:可以得出結(jié)論,公平鎖指的是哪個(gè)線程先運(yùn)行,那就可以先得到鎖。非公平鎖是不管線程是否是先運(yùn)行,新的線程都有可能搶占已經(jīng)在排隊(duì)的線程的鎖。

private void test3() {
    Service service = new Service();
    ThreadClass tcArray[] = new ThreadClass[10];
    for(int i=0;i<10;i++){
        tcArray[i] = new ThreadClass(service);
        tcArray[i].start();
    }
}

public class Service {
    ReentrantLock lock = new ReentrantLock(true);
    Service() {
    }

    void getThreadName() {
        System.out.println(Thread.currentThread().getName() + " 已經(jīng)被鎖定");
    }
}
public class ThreadClass extends Thread{
    private Service service;
    ThreadClass(Service service) {
        this.service = service;
    }
    public void run(){
        System.out.println(Thread.currentThread().getName() + " 搶到了鎖");
        service.lock.lock();
        service.getThreadName();
        service.lock.unlock();
    }
}
//當(dāng)ReentrantLock設(shè)置true,也就是公平鎖時(shí)
10-17 19:32:22.422 6459-6523/com.yc.cn.ycbaseadapter I/System.out: Thread-5 搶到了鎖
10-17 19:32:22.422 6459-6523/com.yc.cn.ycbaseadapter I/System.out: Thread-5 已經(jīng)被鎖定
10-17 19:32:22.424 6459-6524/com.yc.cn.ycbaseadapter I/System.out: Thread-6 搶到了鎖
10-17 19:32:22.424 6459-6524/com.yc.cn.ycbaseadapter I/System.out: Thread-6 已經(jīng)被鎖定
10-17 19:32:22.427 6459-6525/com.yc.cn.ycbaseadapter I/System.out: Thread-7 搶到了鎖
10-17 19:32:22.427 6459-6526/com.yc.cn.ycbaseadapter I/System.out: Thread-8 搶到了鎖
10-17 19:32:22.427 6459-6525/com.yc.cn.ycbaseadapter I/System.out: Thread-7 已經(jīng)被鎖定
10-17 19:32:22.427 6459-6526/com.yc.cn.ycbaseadapter I/System.out: Thread-8 已經(jīng)被鎖定
10-17 19:32:22.427 6459-6527/com.yc.cn.ycbaseadapter I/System.out: Thread-9 搶到了鎖
10-17 19:32:22.427 6459-6527/com.yc.cn.ycbaseadapter I/System.out: Thread-9 已經(jīng)被鎖定
10-17 19:32:22.428 6459-6528/com.yc.cn.ycbaseadapter I/System.out: Thread-10 搶到了鎖
10-17 19:32:22.428 6459-6528/com.yc.cn.ycbaseadapter I/System.out: Thread-10 已經(jīng)被鎖定
10-17 19:32:22.429 6459-6529/com.yc.cn.ycbaseadapter I/System.out: Thread-11 搶到了鎖
10-17 19:32:22.429 6459-6529/com.yc.cn.ycbaseadapter I/System.out: Thread-11 已經(jīng)被鎖定
10-17 19:32:22.430 6459-6530/com.yc.cn.ycbaseadapter I/System.out: Thread-12 搶到了鎖
10-17 19:32:22.430 6459-6530/com.yc.cn.ycbaseadapter I/System.out: Thread-12 已經(jīng)被鎖定
10-17 19:32:22.431 6459-6532/com.yc.cn.ycbaseadapter I/System.out: Thread-14 搶到了鎖
10-17 19:32:22.431 6459-6532/com.yc.cn.ycbaseadapter I/System.out: Thread-14 已經(jīng)被鎖定
10-17 19:32:22.432 6459-6531/com.yc.cn.ycbaseadapter I/System.out: Thread-13 搶到了鎖
10-17 19:32:22.433 6459-6531/com.yc.cn.ycbaseadapter I/System.out: Thread-13 已經(jīng)被鎖定


//當(dāng)ReentrantLock設(shè)置false,也就是非公平鎖時(shí)
10-17 19:34:58.102 7089-7183/com.yc.cn.ycbaseadapter I/System.out: Thread-5 搶到了鎖
10-17 19:34:58.102 7089-7184/com.yc.cn.ycbaseadapter I/System.out: Thread-6 搶到了鎖
10-17 19:34:58.103 7089-7183/com.yc.cn.ycbaseadapter I/System.out: Thread-5 已經(jīng)被鎖定
10-17 19:34:58.103 7089-7185/com.yc.cn.ycbaseadapter I/System.out: Thread-7 搶到了鎖
10-17 19:34:58.103 7089-7185/com.yc.cn.ycbaseadapter I/System.out: Thread-7 已經(jīng)被鎖定
10-17 19:34:58.103 7089-7184/com.yc.cn.ycbaseadapter I/System.out: Thread-6 已經(jīng)被鎖定
10-17 19:34:58.104 7089-7186/com.yc.cn.ycbaseadapter I/System.out: Thread-8 搶到了鎖
10-17 19:34:58.105 7089-7186/com.yc.cn.ycbaseadapter I/System.out: Thread-8 已經(jīng)被鎖定
10-17 19:34:58.108 7089-7187/com.yc.cn.ycbaseadapter I/System.out: Thread-9 搶到了鎖
10-17 19:34:58.108 7089-7187/com.yc.cn.ycbaseadapter I/System.out: Thread-9 已經(jīng)被鎖定
10-17 19:34:58.111 7089-7188/com.yc.cn.ycbaseadapter I/System.out: Thread-10 搶到了鎖
10-17 19:34:58.112 7089-7188/com.yc.cn.ycbaseadapter I/System.out: Thread-10 已經(jīng)被鎖定
10-17 19:34:58.112 7089-7189/com.yc.cn.ycbaseadapter I/System.out: Thread-11 搶到了鎖
10-17 19:34:58.113 7089-7189/com.yc.cn.ycbaseadapter I/System.out: Thread-11 已經(jīng)被鎖定
10-17 19:34:58.113 7089-7193/com.yc.cn.ycbaseadapter I/System.out: Thread-14 搶到了鎖
10-17 19:34:58.113 7089-7193/com.yc.cn.ycbaseadapter I/System.out: Thread-14 已經(jīng)被鎖定
10-17 19:34:58.115 7089-7190/com.yc.cn.ycbaseadapter I/System.out: Thread-12 搶到了鎖
10-17 19:34:58.115 7089-7190/com.yc.cn.ycbaseadapter I/System.out: Thread-12 已經(jīng)被鎖定
10-17 19:34:58.116 7089-7191/com.yc.cn.ycbaseadapter I/System.out: Thread-13 搶到了鎖
10-17 19:34:58.116 7089-7191/com.yc.cn.ycbaseadapter I/System.out: Thread-13 已經(jīng)被鎖定

5.問答測(cè)試題 5.1 ReentrantLock和synchronized使用分析

ReentrantLock是Lock的實(shí)現(xiàn)類,是一個(gè)互斥的同步器,在多線程高競(jìng)爭(zhēng)條件下,ReentrantLock比synchronized有更加優(yōu)異的性能表現(xiàn)。

1 用法比較

Lock使用起來比較靈活,但是必須有釋放鎖的配合動(dòng)作

Lock必須手動(dòng)獲取與釋放鎖,而synchronized不需要手動(dòng)釋放和開啟鎖

Lock只適用于代碼塊鎖,而synchronized可用于修飾方法、代碼塊等

2 特性比較

ReentrantLock的優(yōu)勢(shì)體現(xiàn)在:

具備嘗試非阻塞地獲取鎖的特性:當(dāng)前線程嘗試獲取鎖,如果這一時(shí)刻鎖沒有被其他線程獲取到,則成功獲取并持有鎖

能被中斷地獲取鎖的特性:與synchronized不同,獲取到鎖的線程能夠響應(yīng)中斷,當(dāng)獲取到鎖的線程被中斷時(shí),中斷異常將會(huì)被拋出,同時(shí)鎖會(huì)被釋放

超時(shí)獲取鎖的特性:在指定的時(shí)間范圍內(nèi)獲取鎖;如果截止時(shí)間到了仍然無法獲取鎖,則返回

3 注意事項(xiàng)

在使用ReentrantLock類的時(shí),一定要注意三點(diǎn):

在finally中釋放鎖,目的是保證在獲取鎖之后,最終能夠被釋放

不要將獲取鎖的過程寫在try塊內(nèi),因?yàn)槿绻讷@取鎖時(shí)發(fā)生了異常,異常拋出的同時(shí),也會(huì)導(dǎo)致鎖無故被釋放。

ReentrantLock提供了一個(gè)newCondition的方法,以便用戶在同一鎖的情況下可以根據(jù)不同的情況執(zhí)行等待或喚醒的動(dòng)作。

關(guān)于其他內(nèi)容介紹 01.關(guān)于博客匯總鏈接

1.技術(shù)博客匯總

2.開源項(xiàng)目匯總

3.生活博客匯總

4.喜馬拉雅音頻匯總

5.其他匯總

02.關(guān)于我的博客

我的個(gè)人站點(diǎn):www.yczbj.org,www.ycbjie.cn

github:https://github.com/yangchong211

知乎:https://www.zhihu.com/people/...

簡(jiǎn)書:http://www.jianshu.com/u/b7b2...

csdn:http://my.csdn.net/m0_37700275

喜馬拉雅聽書:http://www.ximalaya.com/zhubo...

開源中國:https://my.oschina.net/zbj161...

泡在網(wǎng)上的日子:http://www.jcodecraeer.com/me...

郵箱:yangchong211@163.com

阿里云博客:https://yq.aliyun.com/users/a... 239.headeruserinfo.3.dT4bcV

segmentfault頭條:https://segmentfault.com/u/xi...

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/71744.html

相關(guān)文章

  • Java中的顯示鎖ReentrantLock使用與原理

    摘要:使當(dāng)前線程休眠,不可調(diào)度。這三種情況下會(huì)恢復(fù)其它線程調(diào)用了,當(dāng)前線程恰好被選中了恢復(fù)執(zhí)行其它線程調(diào)用了假醒。 考慮一個(gè)場(chǎng)景,輪流打印0-100以內(nèi)的技術(shù)和偶數(shù)。通過使用 synchronize 的 wait,notify機(jī)制就可以實(shí)現(xiàn),核心思路如下: 使用兩個(gè)線程,一個(gè)打印奇數(shù),一個(gè)打印偶數(shù)。這兩個(gè)線程會(huì)共享一個(gè)數(shù)據(jù),數(shù)據(jù)每次自增,當(dāng)打印奇數(shù)的線程發(fā)現(xiàn)當(dāng)前要打印的數(shù)字不是奇數(shù)時(shí),執(zhí)行...

    tabalt 評(píng)論0 收藏0
  • 線程同步技術(shù)匯總

    摘要:備注整理一些同步技術(shù),方便日后回顧。單機(jī)多線程情況解讀層面的同步技術(shù),字節(jié)碼實(shí)現(xiàn)。能夠響應(yīng)中斷,讓等待狀態(tài)的線程停止等待。每個(gè)子線程執(zhí)行完畢以后,執(zhí)行函數(shù),字段減,直到字段變?yōu)椤? 備注:整理一些同步技術(shù),方便日后回顧。目前技術(shù)還在學(xué)習(xí)中,了解到同步方面的新知識(shí)會(huì)補(bǔ)充到本文。 單機(jī)多線程情況: synchronized 1、解讀: (1)jvm層面的同步技術(shù),字節(jié)碼實(shí)現(xiàn)。當(dāng)...

    hot_pot_Leo 評(píng)論0 收藏0
  • 線程同步技術(shù)匯總

    摘要:備注整理一些同步技術(shù),方便日后回顧。單機(jī)多線程情況解讀層面的同步技術(shù),字節(jié)碼實(shí)現(xiàn)。能夠響應(yīng)中斷,讓等待狀態(tài)的線程停止等待。每個(gè)子線程執(zhí)行完畢以后,執(zhí)行函數(shù),字段減,直到字段變?yōu)椤? 備注:整理一些同步技術(shù),方便日后回顧。目前技術(shù)還在學(xué)習(xí)中,了解到同步方面的新知識(shí)會(huì)補(bǔ)充到本文。 單機(jī)多線程情況: synchronized 1、解讀: (1)jvm層面的同步技術(shù),字節(jié)碼實(shí)現(xiàn)。當(dāng)...

    Donne 評(píng)論0 收藏0
  • java并發(fā)編程學(xué)習(xí)13--Atomic數(shù)據(jù)結(jié)構(gòu)簡(jiǎn)介

    摘要:介紹中無鎖的線程安全整數(shù),一個(gè)提供原子操作的的類。在語言中,和操作并不是線程安全的,在使用的時(shí)候,不可避免的會(huì)用到關(guān)鍵字。而則通過一種線程安全的加減操作接口。就是的意思,比較并操作。有個(gè)操作數(shù),內(nèi)存值,舊的預(yù)期值,要修改的新值。 【介紹 JAVA 中無鎖的線程安全整數(shù) AtomicInteger,一個(gè)提供原子操作的Integer的類。在Java語言中,++i和i++操作并不是線程安全的...

    李增田 評(píng)論0 收藏0
  • Java鎖機(jī)制

    摘要:它倆是不沖突的,也就是說獲取了類鎖的線程和獲取了對(duì)象鎖的線程是不沖突的可重入鎖住了鎖住了當(dāng)線程進(jìn)入到的方法時(shí),此時(shí)拿到了實(shí)例對(duì)象的鎖。當(dāng)一個(gè)線程執(zhí)行的代碼出現(xiàn)異常時(shí),其所持有的鎖會(huì)自動(dòng)釋放。 Java鎖機(jī)制 synchronized鎖 synchronized 簡(jiǎn)介 synchronized是Java的一個(gè)關(guān)鍵字,它能夠?qū)⒋a塊(方法)鎖起來 synchronized是一種互...

    FreeZinG 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<