每個(gè)人都曾試圖在平淡的學(xué)習(xí)、工作和生活中寫一篇文章。寫作是培養(yǎng)人的觀察,、聯(lián)想,、想象,、思維和記憶的重要手段,。那么我們?cè)撊绾螌懸黄^為完美的范文呢,?接下來小編就給大家介紹一下優(yōu)秀的范文該怎么寫,我們一起來看一看吧,。
java線程的生命周期詳解 java線程的生命周期有幾個(gè)階段篇一
線程是程序中一個(gè)單一的順序控制流程。進(jìn)程內(nèi)一個(gè)相對(duì)獨(dú)立的,、可調(diào)度的執(zhí)行單元,,是系統(tǒng)獨(dú)立調(diào)度和分派cpu的基本單位指運(yùn)行中的程序的調(diào)度單位。下面是小編分享的java線程的生命周期,,一起來看一下吧,。
在java程序中創(chuàng)建線程有幾種方法。每個(gè)java程序至少包含一個(gè)線程:主線程,。其它線程都是通過thread構(gòu)造器或?qū)嵗^承類thread的類來創(chuàng)建的,。
java線程可以通過直接實(shí)例化thread對(duì)象或?qū)嵗^承thread的對(duì)象來創(chuàng)建其它線程。在線程基礎(chǔ)中的示例(其中,,我們?cè)谑腌娭畠?nèi)計(jì)算盡量多的素?cái)?shù))中,,我們通過實(shí)例化calculateprimes類型的對(duì)象(它繼承了thread),創(chuàng)建了一個(gè)線程,。
當(dāng)我們討論java程序中的線程時(shí),,也許會(huì)提到兩個(gè)相關(guān)實(shí)體:完成工作的實(shí)際線程或代表線程的thread對(duì)象。正在運(yùn)行的線程通常是由操作系統(tǒng)創(chuàng)建的;thread對(duì)象是由javavm創(chuàng)建的,,作為控制相關(guān)線程的一種方式,。
創(chuàng)建線程和啟動(dòng)線程并不相同
在一個(gè)線程對(duì)新線程的thread對(duì)象調(diào)用start()方法之前,這個(gè)新線程并沒有真正開始執(zhí)行,。thread對(duì)象在其線程真正啟動(dòng)之前就已經(jīng)存在了,,而且其線程退出之后仍然存在,。這可以讓您控制或獲取關(guān)于已創(chuàng)建的線程的信息,即使線程還沒有啟動(dòng)或已經(jīng)完成了,。
通常在構(gòu)造器中通過start()啟動(dòng)線程并不是好主意,。這樣做,會(huì)把部分構(gòu)造的對(duì)象暴露給新的`線程,。如果對(duì)象擁有一個(gè)線程,,那么它應(yīng)該提供一個(gè)啟動(dòng)該線程的start()或init()方法,而不是從構(gòu)造器中啟動(dòng)它,。(請(qǐng)參閱參考資料,,獲取提供此概念更詳細(xì)說明的文章鏈接。)
java線程會(huì)以以下三種方式之一結(jié)束:
java線程到達(dá)其run()方法的末尾,。
java線程拋出一個(gè)未捕獲到的exception或error,。
另一個(gè)java線程調(diào)用一個(gè)棄用的stop()方法。棄用是指這些方法仍然存在,,但是您不應(yīng)該在新代碼中使用它們,,并且應(yīng)該盡量從現(xiàn)有代碼中除去它們。
當(dāng)java程序中的所有線程都完成時(shí),,程序就退出了,。
加入java線程
threadapi包含了等待另一個(gè)線程完成的方法:join()方法。當(dāng)調(diào)用()時(shí),,調(diào)用線程將阻塞,,直到目標(biāo)線程完成為止。
()通常由使用線程的程序使用,,以將大問題劃分成許多小問題,,每個(gè)小問題分配一個(gè)線程。本章結(jié)尾處的示例創(chuàng)建了十個(gè)線程,,啟動(dòng)它們,,然后使用()等待它們?nèi)客瓿伞?/p>
除了何時(shí)使用()()外,線程調(diào)度和執(zhí)行的計(jì)時(shí)是不確定的,。如果兩個(gè)線程同時(shí)運(yùn)行,,而且都不等待,您必須假設(shè)在任何兩個(gè)指令之間,,其它線程都可以運(yùn)行并修改程序變量,。如果線程要訪問其它線程可以看見的變量,如從靜態(tài)字段(全局變量)直接或間接引用的數(shù)據(jù),,則必須使用同步以確保數(shù)據(jù)一致性,。
在以下的簡(jiǎn)單示例中,我們將創(chuàng)建并啟動(dòng)兩個(gè)線程,:
classtwothreads{
staticclassthread1extendsthread{
voidrun(){
n("a");
n("b");
6.}
7.}
staticclassthread2extendsthread{
voidrun(){
n("1");
n("2");
12.}
13.}
staticvoidmain(string[]args){
ead1().start();
ead2().start();
17.}
18.}
我們并不知道這些行按什么順序執(zhí)行,,只知道“1”在“2”之前打印,,以及“a”在“b”之前打印。輸出可能是以下結(jié)果中的任何一種:
12ab
1a2b
1ab2
a12b
a1b2
ab12
不僅不同機(jī)器之間的結(jié)果可能不同,,而且在同一機(jī)器上多次運(yùn)行同一程序也可能生成不同結(jié)果,。永遠(yuǎn)不要假設(shè)一個(gè)線程會(huì)在另一個(gè)線程之前執(zhí)行某些操作,除非您已經(jīng)使用了同步以強(qiáng)制一個(gè)特定的執(zhí)行順序,。
休眠
threadapi包含了一個(gè)sleep()方法,,它將使當(dāng)前線程進(jìn)入等待狀態(tài),直到過了一段指定時(shí)間,,或者直到另一個(gè)線程對(duì)當(dāng)前線程的 upt(),,從而中斷了線程。當(dāng)過了指定時(shí)間后,,線程又將變成可運(yùn)行的,,并且回到調(diào)度程序的可運(yùn)行線程隊(duì)列中,。
upt()的調(diào)用而中斷的,,那么休眠的線程會(huì)拋出interruptedexception,這樣線程就知道它是由中斷喚醒的,,就不必查看計(jì)時(shí)器是否過期,。
()()一樣,但它并不引起休眠,,而只是暫停當(dāng)前線程片刻,,這樣其它線程就可以運(yùn)行了。在大多數(shù)實(shí)現(xiàn)中,,()時(shí),,較低優(yōu)先級(jí)的線程就不會(huì)運(yùn)行。
calculateprimes示例使用了一個(gè)后臺(tái)線程計(jì)算素?cái)?shù),,然后休眠十秒鐘,。當(dāng)計(jì)時(shí)器過期后,它就會(huì)設(shè)置一個(gè)標(biāo)志,,表示已經(jīng)過了十秒,。
我們提到過當(dāng)java程序的所有線程都完成時(shí),該程序就退出,,但這并不完全正確,。隱藏的系統(tǒng)線程,如垃圾收集線程和由jvm創(chuàng)建的其它線程會(huì)怎么樣?我們沒有辦法停止這些線程,。如果那些線程正在運(yùn)行,,那么java程序怎么退出呢?
這些系統(tǒng)線程稱作守護(hù)程序線程。java程序?qū)嶋H上是在它的所有非守護(hù)程序線程完成后退出的。
任何線程都可以變成守護(hù)程序線程,。mon()方法來指明某個(gè)線程是守護(hù)程序線程,。您也許想要使用守護(hù)程序線程作為在程序中創(chuàng)建的后臺(tái)線程,如計(jì)時(shí)器線程或其它延遲的事件線程,,只有當(dāng)其它非守護(hù)程序線程正在運(yùn)行時(shí),,這些線程才有用。
示例:用多個(gè)java線程分解大任務(wù)
在這個(gè)示例中,,tenthreads顯示了一個(gè)創(chuàng)建了十個(gè)線程的程序,,每個(gè)線程都執(zhí)行一部分工作。該程序等待所有線程全部完成,,然后收集結(jié)果,。
19./**
20.*createstenthreadstosearchforthemaximumvalueofalargematrix.
21.*eachthreadsearchesoneportionofthematrix.
22.*/
classtenthreads{
estaticclassworkerthreadextendsthread{
=_value;
[]ourarray;
workerthread(int[]ourarray){
ay=ourarray;
29.}
30.//findthemaximumvalueinourparticularpieceofthearray
3voidrun(){
(inti=0;i
=(max,ourarray[i]);
34.}
intgetmax(){
max;
37.}
38.}
3staticvoidmain(string[]args){
thread[]threads=newworkerthread[10];
[][]bigmatrix=getbighairymatrix();
=_value;
43.//giveeachthreadasliceofthematrixtoworkwith
(inti=0;i<10;i++){
s[i]=newworkerthread(bigmatrix[i]);
s[i].start();
47.}
48.//waitforeachthreadtofinish
{
(inti=0;i<10;i++){
s[i].join();
=(max,threads[i].getmax());
53.}
54.}
(interruptedexceptione){
56.//fallthrough
57.}
n("maximumvaluewas"+max);
59.}
60.}
就象程序一樣,線程有生命周期:它們啟動(dòng),、執(zhí)行,,然后完成。一個(gè)程序或進(jìn)程也許包含多個(gè)線程,,而這些線程看來互相單獨(dú)地執(zhí)行,。
線程是通過實(shí)例化thread對(duì)象或?qū)嵗^承thread的對(duì)象來創(chuàng)建的,但在對(duì)新的thread對(duì)象調(diào)用start()方法之前,,這個(gè)線程并沒有開始執(zhí)行,。當(dāng)線程運(yùn)行到其run()方法的末尾或拋出未經(jīng)處理的異常時(shí),它們就結(jié)束了,。
sleep()方法可以用于等待一段特定時(shí)間;而join()方法可能用于等到另一個(gè)線程完成,。
s("content_relate");
【java線程的生命周期】相關(guān)文章:
java多線程介紹
12-07
java多線程教程
11-21
java線程編程中的主線程詳細(xì)介紹
11-25
java單線程多線程的實(shí)現(xiàn)與方法
12-05
java多線程之線程間的通信方式解析
11-25
java多線程的開發(fā)技巧
11-11
java多線程的基本使用
11-10
什么是java主線程
12-07
關(guān)于java多線程介紹
11-22