java多線程編程詳解-詳細(xì)操作例子

java多線程編程詳解-詳細(xì)操作例子

ID:26717332

大小:58.00 KB

頁數(shù):22頁

時(shí)間:2018-11-28

java多線程編程詳解-詳細(xì)操作例子_第1頁
java多線程編程詳解-詳細(xì)操作例子_第2頁
java多線程編程詳解-詳細(xì)操作例子_第3頁
java多線程編程詳解-詳細(xì)操作例子_第4頁
java多線程編程詳解-詳細(xì)操作例子_第5頁
資源描述:

《java多線程編程詳解-詳細(xì)操作例子》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在教育資源-天天文庫(kù)。

1、一、理解多線程多線程是這樣一種機(jī)制,它允許在程序中并發(fā)執(zhí)行多個(gè)指令流,每個(gè)指令流都稱為一個(gè)線程,彼此間互相獨(dú)立。線程又稱為輕量級(jí)進(jìn)程,它和進(jìn)程一樣擁有獨(dú)立的執(zhí)行控制,由操作系統(tǒng)負(fù)責(zé)調(diào)度,區(qū)別在于線程沒有獨(dú)立的存儲(chǔ)空間,而是和所屬進(jìn)程中的其它線程共享一個(gè)存儲(chǔ)空間,這使得線程間的通信遠(yuǎn)較進(jìn)程簡(jiǎn)單。具體到j(luò)ava內(nèi)存模型,由于Java被設(shè)計(jì)為跨平臺(tái)的語言,在內(nèi)存管理上,顯然也要有一個(gè)統(tǒng)一的模型。系統(tǒng)存在一個(gè)主內(nèi)存(MainMemory),Java中所有變量都儲(chǔ)存在主存中,對(duì)于所有線程都是共享的。每條線程都有自己的工作內(nèi)存(WorkingMemory),工作內(nèi)存中保存的是主存中某些變量的拷貝

2、,線程對(duì)所有變量的操作都是在工作內(nèi)存中進(jìn)行,線程之間無法相互直接訪問,變量傳遞均需要通過主存完成。多個(gè)線程的執(zhí)行是并發(fā)的,也就是在邏輯上“同時(shí)”,而不管是否是物理上的“同時(shí)”。如果系統(tǒng)只有一個(gè)CPU,那么真正的“同時(shí)”是不可能的。多線程和傳統(tǒng)的單線程在程序設(shè)計(jì)上最大的區(qū)別在于,由于各個(gè)線程的控制流彼此獨(dú)立,使得各個(gè)線程之間的代碼是亂序執(zhí)行的,將會(huì)帶來線程調(diào)度,同步等問題。二、在Java中實(shí)現(xiàn)多線程我們不妨設(shè)想,為了創(chuàng)建一個(gè)新的線程,我們需要做些什么?很顯然,我們必須指明這個(gè)線程所要執(zhí)行的代碼,而這就是在Java中實(shí)現(xiàn)多線程我們所需要做的一切!作為一個(gè)完全面向?qū)ο蟮恼Z言,Java提供了

3、類java.lang.Thread來方便多線程編程,這個(gè)類提供了大量的方法來方便我們控制自己的各個(gè)線程。那么如何提供給Java我們要線程執(zhí)行的代碼呢?讓我們來看一看Thread類。Thread類最重要的方法是run(),它為Thread類的方法start()所調(diào)用,提供我們的線程所要執(zhí)行的代碼。為了指定我們自己的代碼,只需要覆蓋它!方法一:繼承Thread類,重寫方法run(),我們?cè)趧?chuàng)建Thread類的子類中重寫run(),加入線程所要執(zhí)行的代碼即可。下面是一個(gè)例子:publicclassTwoThreadextendsThread{publicvoidrun(){for(inti

4、=0;i<10;i++){System.out.println("Newthread");}}publicstaticvoidmain(String[]args){TwoThreadtt=newTwoThread();tt.start();for(inti=0;i<10;i++){System.out.println("Mainthread");}}}這種方法簡(jiǎn)單明了,符合大家的習(xí)慣,但是,它也有一個(gè)很大的缺點(diǎn),那就是如果我們的類已經(jīng)從一個(gè)類繼承,則無法再繼承Thread類。方法二:實(shí)現(xiàn)Runnable接口Runnable接口只有一個(gè)方法run(),我們聲明自己的類實(shí)現(xiàn)Runnabl

5、e接口并提供這一方法,將我們的線程代碼寫入其中,就完成了這一部分的任務(wù)。但是Runnable接口并沒有任何對(duì)線程的支持,我們還必須創(chuàng)建Thread類的實(shí)例,這一點(diǎn)通過Thread類的構(gòu)造函數(shù)publicThread(Runnabletarget);來實(shí)現(xiàn)。下面是一個(gè)例子:publicclassMyThreadimplementsRunnable{intcount=1,number;publicMyThread(intnum){number=num;System.out.println("創(chuàng)建線程"+number);}publicvoidrun(){//實(shí)現(xiàn)了接口的run()方法whi

6、le(true){System.out.println("線程"+number+":計(jì)數(shù)"+count);if(++count==6)return;}}publicstaticvoidmain(Stringargs[]){for(inti=0;i<5;i++)newThread(newMyThread(i+1)).start();}}使用Runnable接口來實(shí)現(xiàn)多線程使得我們能夠在一個(gè)類中包容所有的代碼,有利于封裝下面讓我們一起來研究一下多線程使用中的一些問題。三、線程的四種狀態(tài)1、新狀態(tài):線程已被創(chuàng)建但尚未執(zhí)行(start()尚未被調(diào)用)。2、可執(zhí)行狀態(tài):線程可以執(zhí)行,雖然不一定

7、正在執(zhí)行。CPU時(shí)間隨時(shí)可能被分配給該線程,從而使得它執(zhí)行。3、阻塞狀態(tài):線程不會(huì)被分配CPU時(shí)間,無法執(zhí)行;可能阻塞于I/O,或者阻塞于同步鎖。4、死亡狀態(tài):正常情況下run()返回使得線程死亡。調(diào)用stop()或destroy()亦有同樣效果,但是不被推薦,前者會(huì)產(chǎn)生異常,后者是強(qiáng)制終止,不會(huì)釋放鎖。四、線程的優(yōu)先級(jí)線程的優(yōu)先級(jí)代表該線程的重要程度,當(dāng)有多個(gè)線程同時(shí)處于可執(zhí)行狀態(tài)并等待獲得CPU時(shí)間時(shí),線程調(diào)度系統(tǒng)根據(jù)各個(gè)線程的優(yōu)先級(jí)來決定給誰分配CP

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動(dòng)畫的文件,查看預(yù)覽時(shí)可能會(huì)顯示錯(cuò)亂或異常,文件下載后無此問題,請(qǐng)放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫(kù)負(fù)責(zé)整理代發(fā)布。如果您對(duì)本文檔版權(quán)有爭(zhēng)議請(qǐng)及時(shí)聯(lián)系客服。
3. 下載前請(qǐng)仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動(dòng)等原因無法下載或下載錯(cuò)誤,付費(fèi)完成后未能成功下載的用戶請(qǐng)聯(lián)系客服處理。