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

Java并發(fā)中死鎖、活鎖和饑餓是什么意思

 更新時間:2021年11月28日 14:43:07   作者:Shockang  
今天看到的一篇文章,說的很好,再敲了一遍,分享一下有關(guān)于死鎖、活鎖及饑餓的概念和區(qū)別,感興趣的可以了解一下

解答

死鎖是指兩個或者兩個以上的進(jìn)程(或線程)在執(zhí)行過程中,因爭奪資源而造成的一種互相等待的現(xiàn)象,若無外力作用,他們將無法推進(jìn)下去。

如果線程的智力不夠, 且都秉承著“謙讓”的原則,主動將資源釋放給他人使用,那么就會導(dǎo)致資源不斷地在兩個線程間跳動,而沒有一個線程可以同時拿到所有資源正常執(zhí)行。這種情況就是活鎖。

饑餓是指某一個或者多個線程因為種種原因無法獲得所需要的資源,導(dǎo)致一直無法執(zhí)行。比如它的線程優(yōu)先級可能太低,而高優(yōu)先級的線程不斷搶占它需要的資源,導(dǎo)致低優(yōu)先級線程無法工作。?

補充

死鎖

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

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

互相爭奪共享資源

產(chǎn)生死鎖的4大條件

1.互斥條件:共享資源被一個線程占用

2.請求與保持條件(占有且等待):一個進(jìn)程因請求資源而被阻塞時,對已經(jīng)獲得資源保持不釋放

3.不可剝奪條件(不可搶占):進(jìn)程已獲得資源,在未使用完之前,不能進(jìn)行剝奪

4.循環(huán)等待條件:多個線程 循環(huán)等待資源,而且是循環(huán)的互相等待

死鎖如何解決?

只需要破壞上面 4 個條件中的一個就能破壞。

1.請求與保持條件:放大鎖范圍,去除對資源的搶占

2.不剝奪:換成可重入鎖ReentrantLock

3.循環(huán)等待:改成順序加鎖,避免循環(huán)等待

4.互斥是多線程的特性,所以這個條件無法避免

活鎖

是指線程1可以使用資源,但它很禮貌,讓其他線程先使用資源,線程2也可以使用資源,但它很紳士,也讓其他線程先使用資源。這樣你讓我,我讓你,最后兩個線程都無法使用資源?;铈i不會被阻塞,而是不停檢測一個永遠(yuǎn)不可能為真的條件。除去進(jìn)程本身持有的資源外,活鎖狀態(tài)的進(jìn)程會持續(xù)耗費寶貴的CPU時間。

任務(wù)或者執(zhí)行者沒有被阻塞,由于某些條件沒有滿足,導(dǎo)致一直重復(fù)嘗試、失敗、嘗試、失敗。在這期間線程狀態(tài)會不停的改變。

饑餓

是指如果線程T1占用了資源R,線程T2又請求封鎖R,于是T2等待。T3也請求資源R,當(dāng)T1釋放了R上的封鎖后,系統(tǒng)首先批準(zhǔn)了T3的請求,T2仍然等待。然后T4又請求封鎖R,當(dāng)T3釋放了R上的封鎖之后,系統(tǒng)又批準(zhǔn)了T4的請求......,T2可能永遠(yuǎn)等待。

這也就是ReentrantLock顯示鎖里提供的不公平鎖機制(當(dāng)然了,ReentrantLock也提供了公平鎖的機制,由用戶根據(jù)具體的使用場景而決定到底使用哪種鎖策略),不公平鎖能夠提高吞吐量但不可避免的會造成某些線程的饑餓。

產(chǎn)生饑餓的原因

【即線程一直在等待卻無法執(zhí)行的原因】

1.高優(yōu)先級線程搶占資源線程

2.在等待一個本身也處于永久等待完成的對象

3.線程被永久阻塞在一個等待進(jìn)入同步塊的狀態(tài),因為其他線程總是能在他之前持續(xù)地對該同步塊進(jìn)行訪問(比如阻塞在synchronized)

活鎖和死鎖的區(qū)別

死鎖會阻塞,一直等待對方釋放資源,一直處在阻塞狀態(tài);活鎖會不停的改變線程狀態(tài)嘗試獲得資源。

活鎖有可能自行解開,死鎖則不行

?死鎖活鎖與饑餓的區(qū)別

進(jìn)程會處于饑餓狀態(tài)是因為持續(xù)地有其它優(yōu)先級更高的進(jìn)程請求相同的資源。不像死鎖或者活鎖,饑餓能夠被解開。例如,當(dāng)其它高優(yōu)先級的進(jìn)程都終止時并且沒有更高優(yōu)先級的進(jìn)程到達(dá)。

?到此這篇關(guān)于Java并發(fā)中死鎖、活鎖和饑餓是什么意思的文章就介紹到這了,更多相關(guān)死鎖、活鎖和饑餓內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java使用注解實現(xiàn)防止重復(fù)提交實例

    Java使用注解實現(xiàn)防止重復(fù)提交實例

    這篇文章主要介紹了Java使用注解實現(xiàn)防止重復(fù)提交實例,在一些項目中由于用戶誤操作,多次點擊表單提交按鈕,會產(chǎn)生很多次的數(shù)據(jù)交互,為了解決這一問題,本文使用注解來實現(xiàn)防止重復(fù)提交,需要的朋友可以參考下
    2023-07-07
  • Spring Cloud調(diào)用Ribbon的步驟

    Spring Cloud調(diào)用Ribbon的步驟

    Ribbon是Netflix發(fā)布的開源項目,主要功能是提供客戶端的軟件負(fù)載均衡算法和服務(wù)調(diào)用。本文將講述Spring Cloud調(diào)用Ribbon的方法
    2021-05-05
  • Java實現(xiàn)的生成二維碼和解析二維碼URL操作示例

    Java實現(xiàn)的生成二維碼和解析二維碼URL操作示例

    這篇文章主要介紹了Java實現(xiàn)的生成二維碼和解析二維碼URL操作,結(jié)合實例形式分析了Java創(chuàng)建與解析二維碼,以及文件讀寫等相關(guān)操作技巧,需要的朋友可以參考下
    2018-07-07
  • 玩轉(zhuǎn)SpringBoot中的那些連接池(小結(jié))

    玩轉(zhuǎn)SpringBoot中的那些連接池(小結(jié))

    這篇文章主要介紹了玩轉(zhuǎn)SpringBoot中的那些連接池(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • java實現(xiàn)動態(tài)代理方法淺析

    java實現(xiàn)動態(tài)代理方法淺析

    這篇文章主要介紹了java實現(xiàn)動態(tài)代理方法淺析,很實用的功能,需要的朋友可以參考下
    2014-08-08
  • Java實現(xiàn)分布式系統(tǒng)限流

    Java實現(xiàn)分布式系統(tǒng)限流

    這篇文章主要為大家詳細(xì)介紹了Java實現(xiàn)分布式系統(tǒng)限流,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • FastDFS分布式文件系統(tǒng)環(huán)境搭建及安裝過程解析

    FastDFS分布式文件系統(tǒng)環(huán)境搭建及安裝過程解析

    這篇文章主要介紹了FastDFS分布式文件系統(tǒng)環(huán)境搭建及安裝過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • Spring?cloud?Hystrix注解初始化源碼過程解讀

    Spring?cloud?Hystrix注解初始化源碼過程解讀

    這篇文章主要為大家介紹了Hystrix初始化部分,我們從源碼的角度分析一下@EnableCircuitBreaker以及@HystrixCommand注解的初始化過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2023-12-12
  • Springmvc實現(xiàn)文件下載2種實現(xiàn)方法

    Springmvc實現(xiàn)文件下載2種實現(xiàn)方法

    這篇文章主要介紹了Springmvc實現(xiàn)文件下載2種實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • java生成圖片驗證碼示例代碼

    java生成圖片驗證碼示例代碼

    這篇文章主要為大家詳細(xì)介紹了java生成圖片驗證碼示例代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08

最新評論