亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

怎么在Java中實現線程死鎖

發布時間:2021-05-19 16:12:11 來源:億速云 閱讀:160 作者:Leah 欄目:編程語言

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

1、死鎖的定義

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

2、死鎖產生的必要條件

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

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

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

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

怎么在Java中實現線程死鎖

3、產生死鎖的一個例子

/**
 * 一個簡單的死鎖類
 * 當DeadLock類的對象flag==1時(td1),先鎖定o1,睡眠500ms
 * 而td1在睡眠的時候另一個flag==0的對象(td2)線程啟動,先鎖定o2,睡眠500ms
 * td1 睡眠結束后需要鎖定 o2 才能繼續執行,而此時 o2 已被 td2 鎖定;
 * td2 睡眠結束后需要鎖定 o1 才能繼續執行,而此時 o1 已被 td1 鎖定;
 * td1、td2 相互等待,都需要得到對方鎖定的資源才能繼續執行,從而死鎖。
 */
public class DeadLock implements Runnable {
  public int flag = 1;
  //靜態對象是類的所有對象共享的
  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都處于可執行狀態,但JVM線程調度先執行哪個線程是不確定的。
    //td2的run()可能在td1的run()之前運行
    new Thread(td1).start();
    new Thread(td2).start();
  }
}

怎么在Java中實現線程死鎖

4、如何避免死鎖

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

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

怎么在Java中實現線程死鎖

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

怎么在Java中實現線程死鎖

常用的java框架有哪些

1.SpringMVC,Spring Web MVC是一種基于Java的實現了Web MVC設計模式的請求驅動類型的輕量級Web框架。2.Shiro,Apache Shiro是Java的一個安全框架。3.Mybatis,MyBatis 是支持普通 SQL查詢,存儲過程和高級映射的優秀持久層框架。4.Dubbo,Dubbo是一個分布式服務框架。5.Maven,Maven是個項目管理和構建自動化工具。6.RabbitMQ,RabbitMQ是用Erlang實現的一個高并發高可靠AMQP消息隊列服務器。7.Ehcache,EhCache 是一個純Java的進程內緩存框架。

上述內容就是怎么在Java中實現線程死鎖,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

苗栗市| 深州市| 淮安市| 文水县| 廊坊市| 昌乐县| 电白县| 青浦区| 田东县| 察哈| 资溪县| 辉南县| 天峨县| 中卫市| 崇信县| 河津市| 章丘市| 雷波县| 临潭县| 时尚| 资讯| 常州市| 睢宁县| 龙游县| 长宁区| 敦化市| 河间市| 阳高县| 吴忠市| 蒙山县| 阜南县| 视频| 和平县| 乐昌市| 青州市| 滦平县| 绵阳市| 临泉县| 镇原县| 孙吴县| 凤冈县|