如何守護(hù)Java項目中的線程?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的廬陽網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
守護(hù)線程并非虛擬機(jī)內(nèi)部可以提供,用戶也可以自行的設(shè)定守護(hù)線程,方法:public final void setDaemon(boolean on)
;但是有幾點需要注意:
1)、thread.setDaemon(true)必須在thread.start()之前設(shè)置,否則會跑出一個IllegalThreadStateException異常。你不能把正在運(yùn)行的常規(guī)線程設(shè)置為守護(hù)線程。 (備注:這點與守護(hù)進(jìn)程有著明顯的區(qū)別,守護(hù)進(jìn)程是創(chuàng)建后,讓進(jìn)程擺脫原會話的控制+讓進(jìn)程擺脫原進(jìn)程組的控制+讓進(jìn)程擺脫原控制終端的控制;所以說寄托于虛擬機(jī)的語言機(jī)制跟系統(tǒng)級語言有著本質(zhì)上面的區(qū)別)
2)、 在Daemon線程中產(chǎn)生的新線程也是Daemon的。 (這一點又是有著本質(zhì)的區(qū)別了:守護(hù)進(jìn)程fork()出來的子進(jìn)程不再是守護(hù)進(jìn)程,盡管它把父進(jìn)程的進(jìn)程相關(guān)信息復(fù)制過去了,但是子進(jìn)程的進(jìn)程的父進(jìn)程不是init進(jìn)程,所謂的守護(hù)進(jìn)程本質(zhì)上說就是“父進(jìn)程掛掉,init收養(yǎng),然后文件0,1,2都是/dev/null,當(dāng)前目錄到/”)
3)、不是所有的應(yīng)用都可以分配給Daemon線程來進(jìn)行服務(wù),比如讀寫操作或者計算邏輯。因為在Daemon Thread還沒來的及進(jìn)行操作時,虛擬機(jī)可能已經(jīng)退出了。
例子:
//完成文件輸出的守護(hù)線程任務(wù) import java.io.*; class TestRunnable implements Runnable{ public void run(){ try{ Thread.sleep(1000);//守護(hù)線程阻塞1秒后運(yùn)行 File f=new File("daemon.txt"); FileOutputStream os=new FileOutputStream(f,true); os.write("daemon".getBytes()); } catch(IOException e1){ e1.printStackTrace(); } catch(InterruptedException e2){ e2.printStackTrace(); } } } public class TestDemo2{ public static void main(String[] args) throws InterruptedException { Runnable tr=new TestRunnable(); Thread thread=new Thread(tr); thread.setDaemon(true); //設(shè)置守護(hù)線程 thread.start(); //開始執(zhí)行分進(jìn)程 } }
運(yùn)行結(jié)果:文件daemon.txt中沒有"daemon"字符串。
但是如果把thread.setDaemon(true); //設(shè)置守護(hù)線程注釋掉,文件daemon.txt是可以被寫入daemon字符串的
JRE判斷程序是否執(zhí)行結(jié)束的標(biāo)準(zhǔn)是所有的前臺執(zhí)線程行完畢了,而不管后臺線程的狀態(tài),因此,在使用后臺線程候一定要注意這個問題。
但是daemon Thread實際應(yīng)用在那里呢?舉個例子,web服務(wù)器中的Servlet,容器啟動時后臺初始化一個服務(wù)線程,即調(diào)度線程,負(fù)責(zé)處理http請求,然后每個請求過來調(diào)度線程從線程池中取出一個工作者線程來處理該請求,從而實現(xiàn)并發(fā)控制的目的。
網(wǎng)上摘的一個圖,方便大家理解:
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。