中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

java線程之死鎖產生的原因是什么

發布時間:2022-05-12 08:58:52 來源:億速云 閱讀:180 作者:iii 欄目:開發技術

這篇文章主要講解了“java線程之死鎖產生的原因是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“java線程之死鎖產生的原因是什么”吧!

一、什么是死鎖

死鎖是指兩個或兩個以上的進程在執行過程中,由于競爭資源或者由于彼此通信而造成的一種阻塞的現象,若無外力作用,它們都將無法推進下去。此時稱系統處于死鎖狀態或系統產生了死鎖,這些永遠在互相等待的進程稱為死鎖進程。

二、死鎖產生的原因

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

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

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

4、環路等待條件:指在發生死鎖時,必然存在一個進程——資源的環形鏈,即進程集合{P0,P1,P2,···,Pn}中的P0正在等待一個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 {
                    //由于線程運行是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 {
                    //由于線程運行是native方法,我們增加線程睡眠,增加死鎖概率
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                //加鎖stu1
                synchronized (stu1){
                    System.out.println("線程:"+Thread.currentThread().getName()+",持有:"+stu1.getName());
                }
            }
        },"t2").start();
    }

java線程之死鎖產生的原因是什么

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 {
                    //由于線程運行是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 {
                    //由于線程運行是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();
    }

java線程之死鎖產生的原因是什么

四、如何查看死鎖

1、使用jps命令找到運行程序的pid

jps

java線程之死鎖產生的原因是什么

2、jstack查看棧信息

jstack pid

java線程之死鎖產生的原因是什么

發現了一個死鎖

java線程之死鎖產生的原因是什么

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

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

java線程之死鎖產生的原因是什么

感謝各位的閱讀,以上就是“java線程之死鎖產生的原因是什么”的內容了,經過本文的學習后,相信大家對java線程之死鎖產生的原因是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

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

AI

霍州市| 西丰县| 乌鲁木齐市| 北流市| 建湖县| 盖州市| 高陵县| 陕西省| 临安市| 卢氏县| 锡林郭勒盟| 苏尼特左旗| 林芝县| 灌南县| 惠东县| 青龙| 顺义区| 桓台县| 平安县| 女性| 黎城县| 抚顺市| 金门县| 顺昌县| 崇义县| 苏尼特左旗| 交城县| 木里| 临高县| 彩票| 泸州市| 武城县| 星子县| 台南市| 滨州市| 铁岭市| 黔江区| 敦煌市| 修水县| 荣昌县| 扎囊县|