資源描述:
《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