日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java的死锁是什么意思_Java面试题:什么是死锁?如何手写一个死锁(Dead Lock)...

發布時間:2024/10/8 java 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java的死锁是什么意思_Java面试题:什么是死锁?如何手写一个死锁(Dead Lock)... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

要想實現一個死鎖,首先要明白什么是死鎖,我們看一下死鎖的定義:

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

用通俗的話來說就是張三跟李四下飯館吃餃子,張三拿著醋,李四拿著蒜瓣,張三說李四你給我吃點蒜,李四說,那不行,你得先給我醋,要不然我不給你,張三也不樂意了,說你必須先給我蒜瓣,我再給你醋,這種現象就是死鎖。(Dead Lock)

我們知道使用Synchronize鎖兩個對象很容易發生這種事,話不多說,直接上代碼:

package Thread;

public class DumplingDeadLockDemo implements Runnable{

static Object garlic = new Object();

static Object vinegar = new Object();

int flag = 0;

@Override

public void run() {

if (flag == 0) {

synchronized (vinegar) {

try {

Thread.sleep(500);

} catch (InterruptedException e) {return;}

System.out.println("我張三正在吃醋,李四你給我點蒜瓣");

synchronized (garlic) {

System.out.println("我張三終于吃上蒜了,hiahia~");

}

}

}

if (flag == 1) {

synchronized (garlic) {

try {

Thread.sleep(500);

} catch (InterruptedException e) {}

System.out.println("俺李四正在吃蒜,張三你給我點醋");

synchronized (vinegar) {

System.out.println("我李四終于吃上醋了,hiahia~");

}

}

}

}

public static void main(String[] args) {

DumplingDeadLockDemo ZhangSan = new DumplingDeadLockDemo();

DumplingDeadLockDemo LiSi = new DumplingDeadLockDemo();

ZhangSan.flag = 0;

LiSi.flag = 1;

Thread t1 = new Thread(ZhangSan);

Thread t2 = new Thread(LiSi);

t1.start();

t2.start();

}

}

需要注意,新手容易犯的錯是把兩個synchronized分開寫了,那么就永遠都不會成了死鎖,死鎖發生的四個必要條件是:

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

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

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

4)環路等待條件:指在發生死鎖時,必然存在一個進程——資源的環形鏈,即進程集合{P0,P1,P2,···,Pn}中的P0正在等待一個P1占用的資源;P1正在等待P2占用的資源,……,Pn正在等待已被P0占用的資源。

拿我這個例子來說,想要死鎖,必須滿足:

互斥性:張三和李四必須吃了醋再吃蒜或者吃了蒜再吃醋,兩個事件不可同時發生,否則不滿足互斥性自然也不會構成死鎖。

請求和保持條件:至少保證張三拿著醋,李四拿著蒜瓣,但是張三還非得要吃蒜,李四還非得吃醋,否則缺少一個條件都不構成死鎖。

不剝奪條件:張三拿著醋,沒完成吃蒜這個事件,李四絕對不能過來搶,否則不滿足不剝奪條件。

環路等待條件:

一定要構成這種環形等待。

總結

以上是生活随笔為你收集整理的java的死锁是什么意思_Java面试题:什么是死锁?如何手写一个死锁(Dead Lock)...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。