溫馨提示×

溫馨提示×

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

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

java doc線程關鍵代碼的編寫是怎樣的

發(fā)布時間:2021-11-20 17:57:45 來源:億速云 閱讀:136 作者:柒染 欄目:編程語言

這期內容當中小編將會給大家?guī)碛嘘Pjava doc線程關鍵代碼的編寫是怎樣的,文章內容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

java doc線程在使用的時候需要我們不斷學習相關問題,下面我們就詳細的看看如何才能更好使用相關代碼。wait(),notify(),notifyAll()不屬于Thread類,而是屬于Object基礎類,也就是說每個對像都有wait(),notify(),notifyAll()的功能。

因為都個對像都有鎖,鎖是每個對像的基礎,當然操作鎖的方法也是最基礎了.

先看java doc線程怎么說:

wait導致當前的線程等待,直到其他線程調用此對象的 notify() 方法或 notifyAll() 方法。當前的線程必須擁有此對象監(jiān)視器。該線程發(fā)布對此監(jiān)視器的所有權并等待,直到其他線程通過調用 notify 方法,或 notifyAll 方法通知在此對象的監(jiān)視器上等待的線程醒來。然后該線程將等到重新獲得對監(jiān)視器的所有權后才能繼續(xù)執(zhí)行.

  • Java線程同步鎖解決共享數據安全

  • Java線程死鎖如何避免這一悲劇

  • Java線程模型如何完善相關的數據處理

  • Java線程同步如何才能排除阻塞

  • Java線程函數關鍵代碼詳細講述

notify喚醒在此對象監(jiān)視器上等待的單個線程。如果所有線程都在此對象上等待,則會選擇喚醒其中一個線程。直到當前的線程放棄此對象上的鎖定,才能繼續(xù)執(zhí)行被喚醒的線程。此方法只應由作為此對象監(jiān)視器的所有者的線程來調用.

"當前的線程必須擁有此對象監(jiān)視器"與"此方法只應由作為此對象監(jiān)視器的所有者的線程來調用"說明wait方法與notify方法必須在同步塊內執(zhí)行,即synchronized(obj之內).

調用對像wait方法后,當前線程釋放對像鎖,進入等待狀態(tài).直到其他線程(也只能是其他線程)通過notify 方法,或 notifyAll.該線程重新獲得對像鎖.繼續(xù)執(zhí)行,記得線程必須重新獲得對像鎖才能繼續(xù)執(zhí)行.因為synchronized代碼塊內沒有鎖是寸步不能走的.看一個很經典的例子:

Java代碼

package ProductAndConsume;   import java.util.List;   public class Consume implements Runnable{   private List container = null;   private int count;   public Consume(List lst){   this.container = lst;   }   public void run() {   while(true){   synchronized (container) {   if(container.size()== 0){   try {   container.wait();//放棄鎖   } catch (InterruptedException e) {   e.printStackTrace();   }   }   try {   Thread.sleep(100);   } catch (InterruptedException e) {   // TODO Auto-generated catch block   e.printStackTrace();   }   container.remove(0);   container.notify();   System.out.println("我吃了"+(++count)+"個");   }   }   }   }   package ProductAndConsume;   import java.util.List;   public class Product implements Runnable {   private List container = null;   private int count;   public Product(List lst) {   this.container = lst;   }    public void run() {   while (true) {   synchronized (container) {   if (container.size() > MultiThread.MAX) {   try {   container.wait();   } catch (InterruptedException e) {   e.printStackTrace();   }   }   try {   Thread.sleep(100);   } catch (InterruptedException e) {   e.printStackTrace();   }   container.add(new Object());   container.notify();   System.out.println("我生產了"+(++count)+"個");   }   }   }   }   package ProductAndConsume;   import java.util.ArrayList;   import java.util.List;   public class MultiThread {   private List container = new ArrayList();   public final static int MAX = 5;   public static void main(String args[]){   MultiThread m = new MultiThread();   new Thread(new Consume(m.getContainer())).start();   new Thread(new Product(m.getContainer())).start();   new Thread(new Consume(m.getContainer())).start();   new Thread(new Product(m.getContainer())).start();   }   public List getContainer() {   return container;   }   public void setContainer(List container) {   this.container = container;   }

上述就是小編為大家分享的java doc線程關鍵代碼的編寫是怎樣的了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

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

AI