欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

怎么在Java中實(shí)現(xiàn)線程死鎖

本篇文章為大家展示了怎么在Java中實(shí)現(xiàn)線程死鎖,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

成都創(chuàng)新互聯(lián)專注于淶源網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供淶源營銷型網(wǎng)站建設(shè),淶源網(wǎng)站制作、淶源網(wǎng)頁設(shè)計(jì)、淶源網(wǎng)站官網(wǎng)定制、微信小程序定制開發(fā)服務(wù),打造淶源網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供淶源網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

1、死鎖的定義

所謂死鎖是指多個(gè)線程因競爭資源而造成的一種僵局(互相等待),若無外力作用,這些進(jìn)程都將無法向前推進(jìn)

2、死鎖產(chǎn)生的必要條件

互斥條件:線程要求對所分配的資源(如打印機(jī))進(jìn)行排他性控制,即在一段時(shí)間內(nèi)某資源僅為一個(gè)線程所占有。此時(shí)若有線程請求該資源,則請求線程只能等待。

不剝奪條件:線程所獲得的資源在未使用完畢之前,不能被其他線程傾向奪走,即只能由獲得該資源的線程自己來釋放(只能是主動(dòng)釋放)。

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

循環(huán)等待條件:存在一種線程資源的循環(huán)等待鏈,鏈中每一個(gè)線程已獲得的資源同時(shí)被鏈中下一個(gè)線程所請求。即存在一個(gè)處于等待狀態(tài)的線程集合{P1,P2,...,Pn},其中Pi等待的資源被P(i+1)占有(i=0,1,..,n-1),Pn等待的資源被P0占有,如下圖。

怎么在Java中實(shí)現(xiàn)線程死鎖

3、產(chǎn)生死鎖的一個(gè)例子

/**
 * 一個(gè)簡單的死鎖類
 * 當(dāng)DeadLock類的對象flag==1時(shí)(td1),先鎖定o1,睡眠500ms
 * 而td1在睡眠的時(shí)候另一個(gè)flag==0的對象(td2)線程啟動(dòng),先鎖定o2,睡眠500ms
 * td1 睡眠結(jié)束后需要鎖定 o2 才能繼續(xù)執(zhí)行,而此時(shí) o2 已被 td2 鎖定;
 * td2 睡眠結(jié)束后需要鎖定 o1 才能繼續(xù)執(zhí)行,而此時(shí) o1 已被 td1 鎖定;
 * td1、td2 相互等待,都需要得到對方鎖定的資源才能繼續(xù)執(zhí)行,從而死鎖。
 */
public class DeadLock implements Runnable {
  public int flag = 1;
  //靜態(tài)對象是類的所有對象共享的
  private static Object o1 = new Object(), o2 = new Object();

  @Override
  public void run() {
    System.out.println("flag="+flag);
    if(flag==1){
      synchronized (o1){
        try {
          Thread.sleep(500);
        } catch (InterruptedException e) {
          e.printStackTrace();
        }
        synchronized (o2){
          System.out.println("1");
        }
      }
    }
    if(flag==0){
      synchronized (o2){
        try {
          Thread.sleep(500);
        } catch (InterruptedException e) {
          e.printStackTrace();
        }
        synchronized (o1){
          System.out.println("0");
        }
      }
    }
  }
  public static void main(String[] args) {
    DeadLock td1 = new DeadLock();
    DeadLock td2 = new DeadLock();
    td1.flag=1;
    td2.flag=0;
    //td1,td2都處于可執(zhí)行狀態(tài),但JVM線程調(diào)度先執(zhí)行哪個(gè)線程是不確定的。
    //td2的run()可能在td1的run()之前運(yùn)行
    new Thread(td1).start();
    new Thread(td2).start();
  }
}

怎么在Java中實(shí)現(xiàn)線程死鎖

4、如何避免死鎖

在有些情況下死鎖是可以避免的。兩種用于避免死鎖的技術(shù)

1)加鎖順序(線程按照一定的順序加鎖

怎么在Java中實(shí)現(xiàn)線程死鎖

2)加鎖時(shí)限(線程獲取鎖的時(shí)候加上一定的時(shí)限,超過時(shí)限則放棄對該鎖的請求,并釋放自己占有的鎖)

怎么在Java中實(shí)現(xiàn)線程死鎖

常用的java框架有哪些

1.SpringMVC,Spring Web MVC是一種基于Java的實(shí)現(xiàn)了Web MVC設(shè)計(jì)模式的請求驅(qū)動(dòng)類型的輕量級Web框架。2.Shiro,Apache Shiro是Java的一個(gè)安全框架。3.Mybatis,MyBatis 是支持普通 SQL查詢,存儲(chǔ)過程和高級映射的優(yōu)秀持久層框架。4.Dubbo,Dubbo是一個(gè)分布式服務(wù)框架。5.Maven,Maven是個(gè)項(xiàng)目管理和構(gòu)建自動(dòng)化工具。6.RabbitMQ,RabbitMQ是用Erlang實(shí)現(xiàn)的一個(gè)高并發(fā)高可靠AMQP消息隊(duì)列服務(wù)器。7.Ehcache,EhCache 是一個(gè)純Java的進(jìn)程內(nèi)緩存框架。

上述內(nèi)容就是怎么在Java中實(shí)現(xiàn)線程死鎖,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

文章標(biāo)題:怎么在Java中實(shí)現(xiàn)線程死鎖
網(wǎng)站路徑:http://chinadenli.net/article36/gigspg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、品牌網(wǎng)站設(shè)計(jì)域名注冊、軟件開發(fā)、營銷型網(wǎng)站建設(shè)、

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)