Java多線程語句具體分類的詳細(xì)介紹_第1頁
Java多線程語句具體分類的詳細(xì)介紹_第2頁
Java多線程語句具體分類的詳細(xì)介紹_第3頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、 Java多線程語句具體分類的詳細(xì)介紹在Java多線程語句中有很多的小的語句需要我們特殊的注意。wait(),notify(),notifyAll()不屬于Thread類,下面我們就來詳細(xì)的看看如何使用這幾個(gè)分類代碼。希望大家有所收獲。而是屬于Object基礎(chǔ)類,也就是說每個(gè)對(duì)像都有wait(),notify(),notifyAll()的功能.因?yàn)槎紓€(gè)對(duì)像都有鎖,鎖是每個(gè)對(duì)像的基礎(chǔ),當(dāng)然操作鎖的方法也是最基礎(chǔ)了.先看java doc怎么說:Java多線程語句中,wait導(dǎo)致當(dāng)前的線程等待,直到其他線程調(diào)用此對(duì)象的 notify() 方法或 notifyAll() 方法。當(dāng)前的線程必須擁有此對(duì)象

2、監(jiān)視器。該線程發(fā)布對(duì)此監(jiān)視器的所有權(quán)并等待,直到其他線程通過調(diào)用 notify 方法,或 notifyAll 方法通知在此對(duì)象的監(jiān)視器上等待的線程醒來。然后該線程將等到重新獲得對(duì)監(jiān)視器的所有權(quán)后才能繼續(xù)執(zhí)行.notify喚醒在此對(duì)象監(jiān)視器上等待的單個(gè)線程。如果所有線程都在此對(duì)象上等待,則會(huì)選擇喚醒其中一個(gè)線程。直到當(dāng)前的線程放棄此對(duì)象上的鎖定,才能繼續(xù)執(zhí)行被喚醒的線程。此方法只應(yīng)由作為此對(duì)象監(jiān)視器的所有者的線程來調(diào)用."當(dāng)前的線程必須擁有此對(duì)象監(jiān)視器"與"此方法只應(yīng)由作為此對(duì)象監(jiān)視器的所有者的線程來調(diào)用"說明wait方法與notify方法必須在同步塊內(nèi)執(zhí)

3、行,即synchronized(obj之內(nèi)).調(diào)用對(duì)像wait方法后,當(dāng)前線程釋放對(duì)像鎖,進(jìn)入等待狀態(tài).直到其他線程(也只能是其他線程)通過notify 方法,或 notifyAll.該線程重新獲得對(duì)像鎖。繼續(xù)執(zhí)行,記得線程必須重新獲得對(duì)像鎖才能繼續(xù)執(zhí)行.因?yàn)閟ynchronized代碼塊內(nèi)沒有鎖是寸步不能走的.看一個(gè)很經(jīng)典的例子:1.Code2.package ProductAndConsume;3.import java.util.List;4.public class Consume implements Runnable5.private List container = null;6

4、.private int count;7.public Consume(List lst)8.this.container = lst;9.10.public void run() 11.while(true)12.synchronized (container) 13.if(container.size()= 0)14.try 15.container.wait();/放棄鎖16. catch (InterruptedException e) 17.e.printStackTrace();18.19.20.try 21.Thread.sleep(100);22. catch (Interru

5、ptedException e) 23./ TODO Auto-generated catch block24.e.printStackTrace();25.26.container.remove(0);27.container.notify();28.System.out.println("我吃了"+(+count)+"個(gè)");29.30.31.32.33.package ProductAndConsume;34.import java.util.List;35.public class Product implements Runnable 36.p

6、rivate List container = null;37.private int count;38.public Product(List lst) 39.this.container = lst;40.41.public void run() 42.while (true) 43.synchronized (container) 44.if (container.size() > MultiThread.MAX) 45.try 46.container.wait();47. catch (InterruptedException e) 48.e.printStackTrace()

7、;49.50.51.try 52.Thread.sleep(100);53. catch (InterruptedException e) 54.e.printStackTrace();55.56.container.add(new Object();57.container.notify();58.System.out.println("我生產(chǎn)了"+(+count)+"個(gè)");59.60.61.62.63.package ProductAndConsume;64.imort java.util.ArrayList;65.import java.util

8、.List;66.public class MultiThread 67.private List container = new ArrayList();68.public final static int MAX = 5;69.public static void main(String args)70.MultiThread m = new MultiThread();71.new Thread(new Consume(m.getContainer().start();72.new Thread(new Product(m.getContainer().start();73.new Thread(new Consume(m.getContainer().start();74.new Thread(new Product(m.getContainer().start();75.76.public List get

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論