java課件08線程2學時_第1頁
java課件08線程2學時_第2頁
java課件08線程2學時_第3頁
java課件08線程2學時_第4頁
java課件08線程2學時_第5頁
已閱讀5頁,還剩10頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

主講教師張智計算機學院網(wǎng)絡(luò)工程系8

線程8.1線程概念8.2創(chuàng)建線程8.3線程同步8.4線程間協(xié)作8.1線程概念認識線程(從OS系統(tǒng)角度)現(xiàn)在的OS都是多任務(wù)操作系統(tǒng),比如你在聽歌的同時還在用QQ聊天。聽歌和聊天就是兩個任務(wù),這兩個任務(wù)是“同時”進行的。一個任務(wù)一般對應(yīng)一個進程,也可能包含好幾個進程。微觀:在一個進程中,可能有多個不同功能的程序塊,例如某個程序塊正在等待打印機,此時CPU是空閑的,其他程序塊可利用這個時機搶占CPU執(zhí)行計算。進程中這樣的程序塊就稱為線程。多線程的目的是為了最大限度的利用CPU資源。8.1線程概念(續(xù))一般的Java程序都是單線程的比如,用Java命令運行一個最簡單的HelloWorld的Java程序時,就啟動了一個JVM進程,JVM找到程序的入口點main(),然后運行main()方法,這樣就產(chǎn)生了一個main線程(主線程)。當main方法結(jié)束后,主線程運行完成。JVM進程也隨即退出。8.1線程概念(續(xù))進程是正在執(zhí)行的程序。線程是進程中一個單一的順序控制流程。一個或更多的線程構(gòu)成了一個進程。線程是進程中的一個實體,是能被OS獨立調(diào)度和分派的基本單位?!綬eturn】8.2創(chuàng)建線程classHelloThreadimplementsRunnable{inti;

publicvoidrun(){

//重寫run()方法i=0;while(true){System.out.println("Hello"+i++);if(i>5)break;

}

}}publicclasstestThread{publicstaticvoidmain(String[]args){

HelloThreadr=newHelloThread();Threadt=newThread(r);t.start();}}Thread類構(gòu)造函數(shù)用Runnable的一個實例來創(chuàng)建一個線程啟動線程線程類實現(xiàn)Runnable接口,并重寫run()方法運行結(jié)果:Hello0Hello1Hello2Hello3Hello4Hello5多線程--前例改進一下

classHelloThreadimplements

Runnable{inti;publicvoidrun(){//重寫Runnable接口的run()方法i=0;while(true){

System.out.println("當前線程:"+Thread.currentThread().getName());

System.out.println("Hello"+i++);if(i>5)break;

}

}}publicclasstestThread{publicstaticvoidmain(String[]args){

HelloThreadr=newHelloThread();

Threadt1=newThread(r);t1.start();Threadt2=newThread(r);t2.start();}}新加語句2個線程當前線程:Thread-0當前線程:Thread-1Hello0當前線程:Thread-0Hello1Hello2當前線程:Thread-1Hello3當前線程:Thread-1Hello4當前線程:Thread-1Hello5當前線程:Thread-0Hello6一個可能的結(jié)果本例中兩個線程共享數(shù)據(jù)和代碼【Return】8.3線程同步由于同一進程的多個線程共享同一片存儲空間,在帶來方便的同時,也帶來了訪問沖突這個嚴重的問題。理解同步:有只蘋果,我拿起來咬一口,放下,你再拿起咬一口,這就是同步。要是大家一起咬,呵呵…類中有一個私有成員:一個蘋果,兩個方法:一個看,一個吃。

不同步:我一“看”,有一個蘋果,我“吃”四分之一;你一“看”,有一個蘋果,也“吃”四分之一??赡艿那闆r是你只能吃到3/4的1/4。

同步:我在吃的時候你看被鎖,等吃完了,你再看,啊3/4個蘋果,那就吃1/3好了,就這樣你也吃了1/4!synchronized關(guān)鍵字synchronized修飾代碼塊時,一個時間內(nèi)只能有一個線程得到執(zhí)行。另一個線程必須等待當前線程執(zhí)行完這個代碼塊以后才能執(zhí)行該代碼塊。synchronized修飾某個方法時,表明該方法只能有一個線程執(zhí)行,其他線程處于等待狀態(tài)。synchronized修飾某個類的聲明時,表明這類中的所有方法都是synchronized的。示例--同步代碼塊classHelloThreadimplementsRunnable{inti;publicvoidrun(){//重寫Runnable接口的run()方法synchronized(this){i=0;while(true){System.out.println("當前線程:"+Thread.currentThread().getName());System.out.println("Hello"+i++);if(i>5)break;}}

}}改寫前例觀察運行結(jié)果(見后)注意寫法當前線程:Thread-0Hello0當前線程:Thread-0Hello1當前線程:Thread-0Hello2當前線程:Thread-0Hello3當前線程:Thread-0Hello4當前線程:Thread-0Hello5當前線程:Thread-1Hello0當前線程:Thread-1Hello1當前線程:Thread-1Hello2當前線程:Thread-1Hello3當前線程:Thread-1Hello4當前線程:Thread-1Hello5同步代碼塊運行結(jié)果第二個線程等待第一個線程結(jié)束后才能訪問同步代碼塊示例--同步方法classHelloThreadimplementsRunnable

inti=0;

synchronized

publicvoidshow(){

System.out.println("當前線程:"+Thread.currentThread().getName()); System.out.println("Hello"+i++);

}

publicvoidrun(){

while(true){

show(); if(i>5)break; } }}改寫前例觀察運行結(jié)果注意區(qū)別前例當前線程:Thread-0Hello0當前線程:Thread-0Hello1當前線程:Thread-0Hello2當前線程:Thread-0Hello3當前線程:Thread-0Hello4當前線程:Thread-0Hello5當前線程:Thread-1Hello6【Return】第二個線程等待第一個線程結(jié)束后才能訪問同步方法注意寫法8.4線程間協(xié)作通常,多線程之間需要協(xié)調(diào)工作。例如,瀏覽器的一個顯示圖片的線程displayThread想要執(zhí)行顯示圖片的任務(wù),必須等待下載線程downloadThread將該圖片下載完畢。如果圖片還沒有下載完,displayThread可以暫停,當downloadThread完成了任務(wù)后,再通知displayThread“圖片準備完畢,可以顯示了”,這時,displayThread繼續(xù)執(zhí)行。簡單的說就是:如果條件不滿足,則等待。當條件滿足時,等待該條件的線程將被喚醒。在Java中,這個機制的實現(xiàn)依賴于wait/notify。wait/notify描述synchronized(obj){while(!condition){

obj.wait();}obj.doSomething();}synchronized(obj){

condition=true;

obj.notify();}在另一線程B中,如果B使得線程A的condition條件滿足了,就可以喚醒線程A。當線程A獲得了obj后,發(fā)現(xiàn)條件condition不滿足,無法繼續(xù)下一處理,于是線程A就wait()。wait()、notify()、notifyAll()wait():釋放已持有的鎖,進入wait隊伍。notify():喚醒wai

溫馨提示

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

評論

0/150

提交評論