青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Merlin

Life was like a box of chocolates. You never know what you're gonna get.

   :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  34 隨筆 :: 0 文章 :: 40 評論 :: 0 Trackbacks
在論壇上面常??吹匠鯇W者對線程的無可奈何,所以總結出了下面一篇文章,希望對一些正在學習使用java線程的初學者有所幫助。

首先要理解線程首先需要了解一些基本的東西,我們現在所使用的大多數操作系統都屬于多任務,分時操作系統。正是由于這種操作系統的出現才有了多線程這個概念。我們使用的windows,linux就屬于此列。什么是分時操作系統呢,通俗一點與就是可以同一時間執行多個程序的操作系統,在自己的電腦上面,你是不是一邊聽歌,一邊聊天還一邊看網頁呢?但實際上,并不上cpu在同時執行這些程序,cpu只是將時間切割為時間片,然后將時間片分配給這些程序,獲得時間片的程序開始執行,不等執行完畢,下個程序又獲得時間片開始執行,這樣多個程序輪流執行一段時間,由于現在cpu的高速計算能力,給人的感覺就像是多個程序在同時執行一樣。
一般可以在同一時間內執行多個程序的操作系統都有進程的概念.一個進程就是一個執行中的程序,而每一個進程都有自己獨立的一塊內存空間,一組系統資源.在進程概念中,每一個進程的內部數據和狀態都是完全獨立的.因此可以想像創建并執行一個進程的系統開像是比較大的,所以線程出現了。在java中,程序通過流控制來執行程序流,程序中單個順序的流控制稱為線程,多線程則指的是在單個程序中可以同時運行多個不同的線程,執行不同的任務.多線程意味著一個程序的多行語句可以看上去幾乎在同一時間內同時運行.(你可以將前面一句話的程序換成進程,進程是程序的一次執行過程,是系統運行程序的基本單位)

線程與進程相似,是一段完成某個特定功能的代碼,是程序中單個順序的流控制;但與進程不同的是,同類的多個線程是共享一塊內存空間和一組系統資源,而線程本身的數據通常只有微處理器的寄存器數據,以及一個供程序執行時使用的堆棧.所以系統在產生一個線程,或者在各個線程之間切換時,負擔要比進程小的多,正因如此,線程也被稱為輕負荷進程(light-weight process).一個進程中可以包含多個線程.

多任務是指在一個系統中可以同時運行多個程序,即有多個獨立運行的任務,每個任務對應一個進程,同進程一樣,一個線程也有從創建,運行到消亡的過程,稱為線程的生命周期.用線程的狀態(state)表明線程處在生命周期的哪個階段.線程有創建,可運行,運行中,阻塞,死亡五中狀態.通過線程的控制與調度可使線程在這幾種狀態間轉化每個程序至少自動擁有一個線程,稱為主線程.當程序加載到內存時,啟動主線程.

[線程的運行機制以及調度模型]
java中多線程就是一個類或一個程序執行或管理多個線程執行任務的能力,每個線程可以獨立于其他線程而獨立運行,當然也可以和其他線程協同運行,一個類控制著它的所有線程,可以決定哪個線程得到優先級,哪個線程可以訪問其他類的資源,哪個線程開始執行,哪個保持休眠狀態。
下面是線程的機制圖:
image

線程的狀態表示線程正在進行的活動以及在此時間段內所能完成的任務.線程有創建,可運行,運行中,阻塞,死亡五中狀態.一個具有生命的線程,總是處于這五種狀態之一:
1.創建狀態
使用new運算符創建一個線程后,該線程僅僅是一個空對象,系統沒有分配資源,稱該線程處于創建狀態(new thread)
2.可運行狀態
使用start()方法啟動一個線程后,系統為該線程分配了除CPU外的所需資源,使該線程處于可運行狀態(Runnable)
3.運行中狀態
Java運行系統通過調度選中一個Runnable的線程,使其占有CPU并轉為運行中狀態(Running).此時,系統真正執行線程的run()方法.
4.阻塞狀態
一個正在運行的線程因某種原因不能繼續運行時,進入阻塞狀態(Blocked)
5.死亡狀態
線程結束后是死亡狀態(Dead)

同一時刻如果有多個線程處于可運行狀態,則他們需要排隊等待CPU資源.此時每個線程自動獲得一個線程的優先級(priority),優先級的高低反映線程的重要或緊急程度.可運行狀態的線程按優先級排隊,線程調度依據優先級基礎上的"先到先服務"原則.
線程調度管理器負責線程排隊和CPU在線程間的分配,并由線程調度算法進行調度.當線程調度管理器選種某個線程時,該線程獲得CPU資源而進入運行狀態.

線程調度是先占式調度,即如果在當前線程執行過程中一個更高優先級的線程進入可運行狀態,則這個線程立即被調度執行.先占式調度分為:獨占式和分時方式.
獨占方式下,當前執行線程將一直執行下去,直 到執行完畢或由于某種原因主動放棄CPU,或CPU被一個更高優先級的線程搶占
分時方式下,當前運行線程獲得一個時間片,時間到時,即使沒有執行完也要讓出CPU,進入可運行狀態,等待下一個時間片的調度.系統選中其他可運行狀態的線程執行
分時方式的系統使每個線程工作若干步,實現多線程同時運行

另外請注意下面的線程調度規則(如果有不理解,不急,往下看):
①如果兩個或是兩個以上的線程都修改一個對象,那么把執行修改的方法定義為被同步的(Synchronized),如果對象更新影響到只讀方法,那么只度方法也應該定義為同步的
②如果一個線程必須等待一個對象狀態發生變化,那么它應該在對象內部等待,而不是在外部等待,它可以調用一個被同步的方法,并讓這個方法調用wait()
③每當一個方法改變某個對象的狀態的時候,它應該調用notifyAll()方法,這給等待隊列的線程提供機會來看一看執行環境是否已發生改變
④記住wait(),notify(),notifyAll()方法屬于Object類,而不是Thread類,仔細檢查看是否每次執行wait()方法都有相應的notify()或notifyAll()方法,且它們作用與相同的對象 在java中每個類都有一個主線程,要執行一個程序,那么這個類當中一定要有main方法,這個man方法也就是java class中的主線程。你可以自己創建線程,有兩種方法,一是繼承Thread類,或是實現Runnable接口。一般情況下,最好避免繼承,因為java中是單根繼承,如果你選用繼承,那么你的類就失去了彈性,當然也不能全然否定繼承Thread,該方法編寫簡單,可以直接操作線程,適用于單重繼承情況。至于選用那一種,具體情況具體分析。


eg.繼承Thread
				public class MyThread_1 extends Thread
{
public void run()
{
//some code
}
}


eg.實現Runnable接口
				public class MyThread_2 implements Runnable
{
public void run()
{
//some code
}
}



當使用繼承創建線程,這樣啟動線程:
				new MyThread_1().start()
		


當使用實現接口創建線程,這樣啟動線程:
				new Thread(new MyThread_2()).start()
		


注意,其實是創建一個線程實例,并以實現了Runnable接口的類為參數傳入這個實例,當執行這個線程的時候,MyThread_2中run里面的代碼將被執行。
下面是完成的例子:

				public class MyThread implements Runnable
{

public void run()
{
System.out.println("My Name is "+Thread.currentThread().getName());
}
public static void main(String[] args)
{
new Thread(new MyThread()).start();
}
}



執行后將打印出:
My Name is Thread-0

你也可以創建多個線程,像下面這樣
				new Thread(new MyThread()).start();
new Thread(new MyThread()).start();
new Thread(new MyThread()).start();



那么會打印出:
My Name is Thread-0
My Name is Thread-1
My Name is Thread-2


看了上面的結果,你可能會認為線程的執行順序是依次執行的,但是那只是一般情況,千萬不要用以為是線程的執行機制;影響線程執行順序的因素有幾點:首先看看前面提到的優先級別


				public class MyThread implements Runnable
{

public void run()
{
System.out.println("My Name is "+Thread.currentThread().getName());
}
public static void main(String[] args)
{
Thread t1=new Thread(new MyThread());
Thread t2=new Thread(new MyThread());
Thread t3=new Thread(new MyThread());
t2.setPriority(Thread.MAX_PRIORITY);//賦予最高優先級
t1.start();
t2.start();
t3.start();
}
}


再看看結果:
My Name is Thread-1
My Name is Thread-0
My Name is Thread-2



線程的優先級分為10級,分別用1到10的整數代表,默認情況是5。上面的t2.setPriority(Thread.MAX_PRIORITY)等價與t2.setPriority(10)
然后是線程程序本身的設計,比如使用sleep,yield,join,wait等方法(詳情請看JDKDocument)

				public class MyThread implements Runnable
{
public void run()
{
try
{
int sleepTime=(int)(Math.random()*100);//產生隨機數字,
Thread.currentThread().sleep(sleepTime);//讓其休眠一定時間,時間又上面sleepTime決定
//public static void sleep(long millis)throw InterruptedException (API)
System.out.println(Thread.currentThread().getName()+" 睡了 "+sleepTime);
}catch(InterruptedException ie)//由于線程在休眠可能被中斷,所以調用sleep方法的時候需要捕捉異常
{
ie.printStackTrace();
}
}
public static void main(String[] args)
{
Thread t1=new Thread(new MyThread());
Thread t2=new Thread(new MyThread());
Thread t3=new Thread(new MyThread());
t1.start();
t2.start();
t3.start();
}
}


執行后觀察其輸出:

Thread-0 睡了 11
Thread-2 睡了 48
Thread-1 睡了 69




上面的執行結果是隨機的,再執行很可能出現不同的結果。由于上面我在run中添加了休眠語句,當線程休眠的時候就會讓出cpu,cpu將會選擇執行處于runnable狀態中的其他線程,當然也可能出現這種情況,休眠的Thread立即進入了runnable狀態,cpu再次執行它。
[線程組概念]
線程是可以被組織的,java中存在線程組的概念,每個線程都是一個線程組的成員,線程組把多個線程集成為一個對象,通過線程組可以同時對其中的多個線程進行操作,如啟動一個線程組的所有線程等.Java的線程組由java.lang包中的Thread——Group類實現.
ThreadGroup類用來管理一組線程,包括:線程的數目,線程間的關系,線程正在執行的操作,以及線程將要啟動或終止時間等.線程組還可以包含線程組.在Java的應用程序中,最高層的線程組是名位main的線程組,在main中還可以加入線程或線程組,在mian的子線程組中也可以加入線程和線程組,形成線程組和線程之間的樹狀繼承關系。像上面創建的線程都是屬于main這個線程組的。
借用上面的例子,main里面可以這樣寫:

				public static void main(String[] args)
{
/***************************************
ThreadGroup(String name)
ThreadGroup(ThreadGroup parent, String name)
***********************************/
ThreadGroup group1=new ThreadGroup("group1");
ThreadGroup group2=new ThreadGroup(group1,"group2");
Thread t1=new Thread(group2,new MyThread());
Thread t2=new Thread(group2,new MyThread());
Thread t3=new Thread(group2,new MyThread());
t1.start();
t2.start();
t3.start();
}



線程組的嵌套,t1,t2,t3被加入group2,group2加入group1。
另外一個比較多就是關于線程同步方面的,試想這樣一種情況,你有一筆存款在銀行,你在一家銀行為你的賬戶存款,而你的妻子在另一家銀行從這個賬戶提款,現在你有1000塊在你的賬戶里面。你存入了1000,但是由于另一方也在對這筆存款進行操作,人家開始執行的時候只看到賬戶里面原來的1000元,當你的妻子提款1000元后,你妻子所在的銀行就認為你的賬戶里面沒有錢了,而你所在的銀行卻認為你還有2000元。
看看下面的例子:

				class BlankSaving //儲蓄賬戶
{
private static int money=10000;
public void add(int i)
{
money=money+i;
System.out.println("Husband 向銀行存入了 [¥"+i+"]");
}
public void get(int i)
{
money=money-i;
System.out.println("Wife 向銀行取走了 [¥"+i+"]");
if(money<0)
System.out.println("余額不足!");
}
public int showMoney()
{
return money;
}
}


class Operater implements Runnable
{
String name;
BlankSaving bs;
public Operater(BlankSaving b,String s)
{
name=s;
bs=b;



}
public static void oper(String name,BlankSaving bs)
{



if(name.equals("husband"))
{
try
{
for(int i=0;i<10;i++)
{
Thread.currentThread().sleep((int)(Math.random()*300));
bs.add(1000);
}
}catch(InterruptedException e){}
}else
{
try
{



for(int i=0;i<10;i++)
{
Thread.currentThread().sleep((int)(Math.random()*300));
bs.get(1000);
}
}catch(InterruptedException e){}
}
}
public void run()
{
oper(name,bs);
}
}
public class BankTest
{
public static void main(String[] args)throws InterruptedException
{
BlankSaving bs=new BlankSaving();
Operater o1=new Operater(bs,"husband");
Operater o2=new Operater(bs,"wife");
Thread t1=new Thread(o1);
Thread t2=new Thread(o2);
t1.start();
t2.start();
Thread.currentThread().sleep(500);
}



}



下面是其中一次的執行結果:



---------first--------------
Husband 向銀行存入了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Husband 向銀行存入了 [¥1000]
Wife 向銀行取走了 [¥1000]
Husband 向銀行存入了 [¥1000]
Wife 向銀行取走了 [¥1000]
Husband 向銀行存入了 [¥1000]
Wife 向銀行取走了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Wife 向銀行取走了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Husband 向銀行存入了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Husband 向銀行存入了 [¥1000]


看到了嗎,這可不是正確的需求,在husband還沒有結束操作的時候,wife就插了進來,這樣很可能導致意外的結果。解決辦法很簡單,就是將對數據進行操作方法聲明為synchronized,當方法被該關鍵字聲明后,也就意味著,如果這個數據被加鎖,只有一個對象得到這個數據的鎖的時候該對象才能對這個數據進行操作。也就是當你存款的時候,這筆賬戶在其他地方是不能進行操作的,只有你存款完畢,銀行管理人員將賬戶解鎖,其他人才能對這個賬戶進行操作。
修改public static void oper(String name,BlankSaving bs)為public static void oper(String name,BlankSaving bs),再看看結果:

Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Husband 向銀行存入了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]
Wife 向銀行取走了 [¥1000]




當丈夫完成操作后,妻子才開始執行操作,這樣的話,對共享對象的操作就不會有問題了。
[wait and notify]
你可以利用這兩個方法很好的控制線程的執行流程,當線程調用wait方法后,線程將被掛起,直到被另一線程喚醒(notify)或則是如果wait方法指定有時間得話,在沒有被喚醒的情況下,指定時間時間過后也將自動被喚醒。但是要注意一定,被喚醒并不是指馬上執行,而是從組塞狀態變為可運行狀態,其是否運行還要看cpu的調度。
事例代碼:

				class MyThread_1 extends Thread
{
Object lock;
public MyThread_1(Object o)
{
lock=o;
}
public void run()
{
try
{
synchronized(lock)
{
System.out.println("Enter Thread_1 and wait");
lock.wait();
System.out.println("be notified");
}
}catch(InterruptedException e){}
}
}
class MyThread_2 extends Thread
{
Object lock;
public MyThread_2(Object o)
{
lock=o;
}
public void run()
{
synchronized(lock)
{
System.out.println("Enter Thread_2 and notify");
lock.notify();
}
}
}
public class MyThread
{
public static void main(String[] args)
{
int[] in=new int[0];//notice
MyThread_1 t1=new MyThread_1(in);
MyThread_2 t2=new MyThread_2(in);
t1.start();
t2.start();
}
}




執行結果如下:
Enter Thread_1 and wait
Enter Thread_2 and notify
Thread_1 be notified


可能你注意到了在使用wait and notify方法得時候我使用了synchronized塊來包裝這兩個方法,這是由于調用這兩個方法的時候線程必須獲得鎖,也就是上面代碼中的lock[],如果你不用synchronized包裝這兩個方法的得話,又或則鎖不一是同一把,比如在MyThread_2中synchronized(lock)改為synchronized(this),那么執行這個程序的時候將會拋出java.lang.IllegalMonitorStateException執行期異常。另外wait and notify方法是Object中的,并不在Thread這個類中。最后你可能注意到了這點:int[] in=new int[0];為什么不是創建new Object而是一個0長度的數組,那是因為在java中創建一個0長度的數組來充當鎖更加高效。

Thread作為java中一重要組成部分,當然還有很多地方需要更深刻的認識,上面只是對Thread的一些常識和易錯問題做了一個簡要的總結,若要真正的掌握java的線程,還需要自己多做總結
posted on 2006-07-12 16:38 Merlin 閱讀(407) 評論(0)  編輯 收藏 引用 所屬分類: java基礎篇
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品久久久久一区| 日韩亚洲视频| 亚洲精品一二| 亚洲激情自拍| 日韩一区二区免费看| 亚洲精品中文字幕在线| 日韩一二三区视频| 亚洲尤物在线视频观看| 欧美在线亚洲综合一区| 欧美成人激情视频免费观看| 欧美国产大片| 一区二区三区高清不卡| 欧美在线免费播放| 欧美xx69| 亚洲区一区二区三区| 国产日韩精品在线| 国产精品精品视频| 国产一区视频网站| 91久久精品久久国产性色也91| 亚洲精品一区二区三区福利| 亚洲在线观看免费| 久久久久久久久蜜桃| 亚洲娇小video精品| 亚洲欧美激情四射在线日| 卡一卡二国产精品| 国产女主播一区| 亚洲三级影片| 久久久久久久综合狠狠综合| 亚洲电影av在线| 亚洲一区二三| 欧美精品一区二区三区蜜桃| 国产情侣一区| 亚洲视频一区二区免费在线观看| 久久精品国语| 亚洲无线一线二线三线区别av| 久久综合九色综合网站| 国产精品爽黄69| 一区二区三区欧美| 欧美高清视频| 久久精品网址| 国产偷久久久精品专区| av成人老司机| 亚洲电影天堂av| 久久久久久午夜| 国产亚洲综合在线| 欧美在线视频日韩| 亚洲视频在线免费观看| 欧美国产日本| 在线精品亚洲| 久久久久久综合| 亚洲综合日韩在线| 国产精品wwwwww| 夜夜嗨av一区二区三区网站四季av | 亚洲视频一区二区| 欧美另类综合| 9l国产精品久久久久麻豆| 欧美国产亚洲另类动漫| 久久久www成人免费毛片麻豆| 国产乱码精品一区二区三区不卡| 在线视频日本亚洲性| 亚洲精品乱码久久久久久| 欧美v日韩v国产v| 亚洲国产精品成人| 欧美国产精品久久| 久久婷婷国产综合国色天香 | 亚洲女人天堂av| 亚洲欧洲精品一区二区精品久久久| 久久国产高清| 久久久天天操| 亚洲桃花岛网站| 国产精品国产福利国产秒拍| 亚洲一区二区精品在线观看| av成人福利| 欧美午夜精品久久久| 午夜在线成人av| 午夜久久久久久| 国产一区二区三区精品久久久| 午夜精品影院| 欧美在线视频全部完| 在线看国产一区| 亚洲欧洲偷拍精品| 国产精品theporn| 久久久精品999| 欧美不卡高清| 亚洲欧美日韩国产成人| 久久不射中文字幕| 亚洲精品一区二区网址| 亚洲一区二区精品在线| 精品成人国产| 99精品免费视频| 国产在线观看一区| 亚洲激情国产| 国产精品亚洲综合久久| 蜜臀av性久久久久蜜臀aⅴ| 欧美激情中文字幕一区二区| 亚洲欧美一区二区三区极速播放 | 亚洲精品久久久久久下一站| 国产精品久久久久久模特 | 在线播放豆国产99亚洲| 日韩午夜电影| 在线成人激情视频| 一本色道久久综合亚洲91| 一区精品在线| 中日韩美女免费视频网址在线观看| 国产一区二区中文字幕免费看| 亚洲人成欧美中文字幕| 国精产品99永久一区一区| 91久久精品国产91性色| 国产一区二区日韩| 一本色道久久综合亚洲91| 亚洲国产电影| 欧美在线视频二区| 亚洲永久在线观看| 欧美激情综合五月色丁香| 久久香蕉精品| 国产精品一级| 99精品视频一区| 亚洲欧洲视频在线| 久久精品二区亚洲w码| 午夜在线观看欧美| 欧美性猛交xxxx乱大交退制版 | 免费日韩av片| 国产日韩欧美麻豆| 中文欧美字幕免费| 亚洲免费av电影| 精久久久久久久久久久| 亚洲视频二区| 在线一区视频| 欧美国产日韩精品| 欧美va天堂在线| 精久久久久久| 久久久不卡网国产精品一区| 久久久久成人网| 国产欧美在线| 亚洲欧美中文日韩在线| 亚洲欧美视频在线观看视频| 国产精品老牛| 亚洲欧美另类综合偷拍| 亚洲综合首页| 国产精品毛片a∨一区二区三区|国| 亚洲黄色av| 妖精视频成人观看www| 欧美女人交a| 99精品免费网| 性欧美大战久久久久久久免费观看| 亚洲品质自拍| 欧美性猛片xxxx免费看久爱 | 伊人久久成人| 亚洲图片欧洲图片日韩av| 老司机67194精品线观看| 一区二区高清视频| 欧美mv日韩mv国产网站app| 国产日韩欧美在线看| 亚洲一区二区三区在线观看视频| 免费看亚洲片| 久久夜色撩人精品| 亚洲高清在线播放| 免费观看在线综合色| 久久性天堂网| 亚洲人成精品久久久久| 亚洲激情网址| 久久久亚洲综合| 欧美一区二区三区视频免费播放 | 国语自产精品视频在线看一大j8 | 亚洲国产色一区| a4yy欧美一区二区三区| 国产精品国产三级国产普通话蜜臀| 亚洲欧美成人综合| 欧美成人高清视频| 亚洲一区二区三区精品在线观看| 国产精品一区三区| 猫咪成人在线观看| 欧美伊人久久| 亚洲欧美综合| 伊人夜夜躁av伊人久久| 欧美黄网免费在线观看| 中文网丁香综合网| 免费久久精品视频| 亚洲免费视频中文字幕| 亚洲国产91| 国产精品色婷婷| 欧美1区免费| 亚洲欧美日韩在线不卡| 欧美激情精品久久久久久免费印度 | 99精品国产一区二区青青牛奶| 国产精品国产三级国产普通话蜜臀 | 亚洲天堂第二页| 激情成人av| 国产精品久久久久久影院8一贰佰| 久久久亚洲精品一区二区三区 | 黄色一区二区三区四区| 国产精品扒开腿做爽爽爽软件 | 亚洲欧洲av一区二区三区久久| 亚洲高清不卡av| 国产精品爽黄69| 欧美日韩国产综合网 | 亚洲毛片在线观看.| 狠狠88综合久久久久综合网| 国产精品卡一卡二卡三| 欧美日韩在线不卡一区|