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

java線程之死鎖

 更新時(shí)間:2022年05月11日 08:42:38   作者:java線程之死鎖  
這篇文章主要介紹了Java線程之死鎖,死鎖是這樣一種情形-多個(gè)線程同時(shí)被阻塞,它們中的一個(gè)或者全部都在等待某個(gè)資源被釋放。由于線程被無限期地阻塞,因此程序不可能正常終止

一、什么是死鎖

死鎖是指兩個(gè)或兩個(gè)以上的進(jìn)程在執(zhí)行過程中,由于競爭資源或者由于彼此通信而造成的一種阻塞的現(xiàn)象,若無外力作用,它們都將無法推進(jìn)下去。此時(shí)稱系統(tǒng)處于死鎖狀態(tài)或系統(tǒng)產(chǎn)生了死鎖,這些永遠(yuǎn)在互相等待的進(jìn)程稱為死鎖進(jìn)程。

二、死鎖產(chǎn)生的原因

1、互斥條件:指進(jìn)程對所分配到的資源進(jìn)行排它性使用,即在一段時(shí)間內(nèi)某資源只由一個(gè)進(jìn)程占用。如果此時(shí)還有其它進(jìn)程請求資源,則請求者只能等待,直至占有資源的進(jìn)程用畢釋放。

2、請求和保持條件:指進(jìn)程已經(jīng)保持至少一個(gè)資源,但又提出了新的資源請求,而該資源已被其它進(jìn)程占有,此時(shí)請求進(jìn)程阻塞,但又對自己已獲得的其它資源保持不放。

3、不剝奪條件:指進(jìn)程已獲得的資源,在未使用完之前,不能被剝奪,只能在使用完時(shí)由自己釋放。

4、環(huán)路等待條件:指在發(fā)生死鎖時(shí),必然存在一個(gè)進(jìn)程——資源的環(huán)形鏈,即進(jìn)程集合{P0,P1,P2,···,Pn}中的P0正在等待一個(gè)P1占用的資源;P1正在等待P2占用的資源,……,Pn正在等待已被P0占用的資源。

三、死鎖演示

1、synchronized

import lombok.Data;
@Data
public class Studnet {
    private String name;
}
 public static void main(String[] args) {
        Studnet stu1=new Studnet();
        stu1.setName("stu1");
        Studnet stu2 = new Studnet();
        stu2.setName("stu2");
        new Thread(()->{
            //加鎖stu1
            synchronized (stu1){
                System.out.println("線程:"+Thread.currentThread().getName()+",持有:"+stu1.getName());
                try {
                    //由于線程運(yùn)行是native方法,我們增加線程睡眠,增加死鎖概率
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                //加鎖stu2
                synchronized (stu2){
                    System.out.println("線程:"+Thread.currentThread().getName()+",持有:"+stu2.getName());
                }
            }
        },"t1").start();
        new Thread(()->{
            //加鎖stu2
            synchronized (stu2){
                System.out.println("線程:"+Thread.currentThread().getName()+",持有:"+stu2.getName());
                try {
                    //由于線程運(yùn)行是native方法,我們增加線程睡眠,增加死鎖概率
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                //加鎖stu1
                synchronized (stu1){
                    System.out.println("線程:"+Thread.currentThread().getName()+",持有:"+stu1.getName());
                }
            }
        },"t2").start();
    }

2、lock

 public static void main(String[] args) {
        Lock lock1=new ReentrantLock();
        Lock lock2=new ReentrantLock();
        new Thread(()->{
            //加鎖lock1
            lock1.lock();
            try {
                System.out.println("線程:"+Thread.currentThread().getName()+",持有:"+"lock1");
                try {
                    //由于線程運(yùn)行是native方法,我們增加線程睡眠,增加死鎖概率
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                //加鎖lock2
                lock2.lock();
                try {
                    System.out.println("線程:"+Thread.currentThread().getName()+",持有:"+"lock2");
                }finally {
                    //釋放lock2
                    lock2.unlock();
                }
            }finally {
                //釋放lock1
                lock1.unlock();
            }
        },"t1").start();
        new Thread(()->{
            lock2.lock();
            try {
                System.out.println("線程:"+Thread.currentThread().getName()+",持有:"+"lock2");
                try {
                    //由于線程運(yùn)行是native方法,我們增加線程睡眠,增加死鎖概率
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                lock1.lock();
                try {
                    System.out.println("線程:"+Thread.currentThread().getName()+",持有:"+"lock1");
                }finally {
                    lock1.unlock();
                }
            }finally {
                lock2.unlock();
            }
        },"t2").start();
    }

四、如何查看死鎖

1、使用jps命令找到運(yùn)行程序的pid

jps

2、jstack查看棧信息

jstack pid

發(fā)現(xiàn)了一個(gè)死鎖

重點(diǎn)摘要,t1、t2線程,交叉持有鎖,等待對方資源。

"t2":- waiting to lock <0x000000076b6f8428> - locked <0x000000076b6f8468> 
#t2 等待鎖0x000000076b6f8428,持有0x000000076b6f8468
"t1":- waiting to lock <0x000000076b6f8468> - locked <0x000000076b6f8428> 
#t1 等待鎖0x000000076b6f8468,持有0x000000076b6f8428

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

相關(guān)文章

  • 利用MultipartFile實(shí)現(xiàn)文件上傳功能

    利用MultipartFile實(shí)現(xiàn)文件上傳功能

    這篇文章主要為大家詳細(xì)介紹了利用MultipartFile實(shí)現(xiàn)文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • SpringBoot使用Log4j過程詳解

    SpringBoot使用Log4j過程詳解

    這篇文章主要介紹了SpringBoot使用Log4j過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • Java中的異常和處理機(jī)制實(shí)例詳解

    Java中的異常和處理機(jī)制實(shí)例詳解

    這篇文章主要介紹了Java中的異常和處理機(jī)制,結(jié)合實(shí)例形式詳細(xì)分析了Java異常與處理機(jī)制的相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2019-05-05
  • Java線程使用同步鎖交替執(zhí)行打印奇數(shù)偶數(shù)的方法

    Java線程使用同步鎖交替執(zhí)行打印奇數(shù)偶數(shù)的方法

    這篇文章主要介紹了Java線程使用同步鎖交替執(zhí)行打印奇數(shù)偶數(shù)的方法。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-01-01
  • 詳解SpringBoot如何實(shí)現(xiàn)多環(huán)境配置

    詳解SpringBoot如何實(shí)現(xiàn)多環(huán)境配置

    在實(shí)際的軟件開發(fā)過程中,一個(gè)應(yīng)用程序通常會(huì)有多個(gè)環(huán)境,pring?Boot?提供了一個(gè)非常靈活和強(qiáng)大的方式來管理這些環(huán)境配置,下面就跟隨小編一起學(xué)習(xí)一下吧
    2023-07-07
  • 利用Java+OpenCV實(shí)現(xiàn)拍照功能

    利用Java+OpenCV實(shí)現(xiàn)拍照功能

    網(wǎng)上大多是利用C語言或者Python實(shí)現(xiàn)拍照功能,本文將為大家介紹另一種方法,即在Java中調(diào)用OpenCV實(shí)現(xiàn)拍照功能,感興趣的可以了解一下
    2022-01-01
  • java 獲取已知文件擴(kuò)展名的代碼

    java 獲取已知文件擴(kuò)展名的代碼

    java 編寫程序獲取已知文件的擴(kuò)展名. 注意: abc.txt的擴(kuò)展名是txt, abc.java.txt的擴(kuò)展名也是txt.,需要的朋友可以參考下
    2017-02-02
  • Java中Iterator迭代器的使用詳解

    Java中Iterator迭代器的使用詳解

    在程序開發(fā)中,經(jīng)常需要遍歷集合中的所有元素。針對這種需求,JDK專門提供了一個(gè)接口java.util.Iterator。本文就來詳細(xì)說說Iterator迭代器的使用,感興趣的可以了解一下
    2022-10-10
  • 詳解pom.xml中maven profile的激活方式

    詳解pom.xml中maven profile的激活方式

    本文主要介紹了詳解pom.xml中maven profile的激活方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • Java基于高精度整型實(shí)現(xiàn)fibonacci數(shù)列的方法

    Java基于高精度整型實(shí)現(xiàn)fibonacci數(shù)列的方法

    這篇文章主要介紹了Java基于高精度整型實(shí)現(xiàn)fibonacci數(shù)列的方法,是比較典型的算法,需要的朋友可以參考下
    2014-09-09

最新評論