偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Java多線(xiàn)程編程基礎(chǔ)之線(xiàn)程對(duì)象

開(kāi)發(fā) 后端
多線(xiàn)程是這樣一種機(jī)制,它允許在程序中并發(fā)執(zhí)行多個(gè)指令流,每個(gè)指令流都稱(chēng)為一個(gè)線(xiàn)程,彼此間互相獨(dú)立。本文主要介紹JAVA多線(xiàn)程的一些基本知識(shí),一起來(lái)看。

在進(jìn)入java平臺(tái)的線(xiàn)程對(duì)象之前,基于基礎(chǔ)篇(一)的一些問(wèn)題,我先插入兩個(gè)基本概念。

線(xiàn)程的并發(fā)與并行

在單CPU系統(tǒng)中,系統(tǒng)調(diào)度在某一時(shí)刻只能讓一個(gè)線(xiàn)程運(yùn)行,雖然這種調(diào)試機(jī)制有多種形式(大多數(shù)是時(shí)間片輪巡為主),但無(wú)論如何,要通過(guò)不斷切換需要運(yùn)行的線(xiàn)程讓其運(yùn)行的方式就叫并發(fā)(concurrent)。而在多CPU系統(tǒng)中,可以讓兩個(gè)以上的線(xiàn)程同時(shí)運(yùn)行,這種可以同時(shí)讓兩個(gè)以上線(xiàn)程同時(shí)運(yùn)行的方式叫做并行(parallel)。

在上面包括以后的所有論述中,請(qǐng)各位朋友諒解,我無(wú)法用最準(zhǔn)確的詞語(yǔ)來(lái)定義儲(chǔ)如并發(fā)和并行這類(lèi)術(shù)語(yǔ),但我以我的經(jīng)驗(yàn)?zāi)芡ㄋ椎馗嬖V大家它是怎么一回事,如果您看到我說(shuō)的一些"標(biāo)準(zhǔn)"文檔上說(shuō)的不一樣,只要意思一致,那您就不要挑刺了。

JAVA線(xiàn)程對(duì)象

現(xiàn)在我們來(lái)開(kāi)始考察JAVA中線(xiàn)程對(duì)象。

在JAVA中,要開(kāi)始一個(gè)線(xiàn)程,有兩種方式。一是直接調(diào)用Thread實(shí)例的start()方法,二是

將Runable實(shí)例傳給一個(gè)Thread實(shí)例然后調(diào)用它的start()方法。

在前面已經(jīng)說(shuō)過(guò),線(xiàn)程對(duì)象和線(xiàn)程是兩個(gè)完全不同的概念。這里我們?cè)俅紊钊胍幌?,生成一個(gè)線(xiàn)程的實(shí)例,并不代表啟動(dòng)了線(xiàn)程。而啟動(dòng)線(xiàn)程是說(shuō)在某個(gè)線(xiàn)程對(duì)象上啟動(dòng)了該實(shí)例對(duì)應(yīng)的線(xiàn)程,當(dāng)該線(xiàn)程結(jié)束后,并不會(huì)就立即消失。

對(duì)于從很多書(shū)籍上可以看到的基礎(chǔ)知識(shí)我就不用多說(shuō)了。既然是基礎(chǔ)知識(shí),我也著重于從普通文檔上讀不到的內(nèi)容。所以本節(jié)我重點(diǎn)要說(shuō)的是兩種線(xiàn)程對(duì)象產(chǎn)生線(xiàn)程方式的區(qū)別。

 

  1. class MyThread extends Thread{  
  2.  public int x = 0;  
  3.  public void run(){  
  4. for(int i=0;i<100;i++){  
  5.   try{  
  6. Thread.sleep(10);  
  7.   }catch(Exception e){}  
  8.   System.out.println(x++);  
  9. }  
  10.  }  

 

如果我們生成MyThread的一個(gè)實(shí)例,然后調(diào)用它的start()方法,那么就產(chǎn)生了這個(gè)實(shí)例對(duì)應(yīng)的線(xiàn)程:

 

  1. public class Test {  
  2.  public static void main(String[] args) throws Exception{  
  3. MyThread mt = new MyThread();  
  4. mt.start();  
  5.  }  

 

不用說(shuō),最終會(huì)打印出0到99,現(xiàn)在我們稍微玩一點(diǎn)花樣:

 

  1. public class Test {  
  2.  public static void main(String[] args) throws Exception{  
  3. MyThread mt = new MyThread();  
  4. mt.start();  
  5. System.out.println(101);  
  6.  }  

 

也不用說(shuō),在基礎(chǔ)篇(一)中我們知道由于單CPU的原因,一般會(huì)先打印101,然后打印0到99。不過(guò)我們可以控制線(xiàn)程讓它按我們的意思來(lái)運(yùn)行:

 

  1. public class Test {  
  2.  public static void main(String[] args) throws Exception{  
  3. MyThread mt = new MyThread();  
  4. mt.start();  
  5. mt.join();  
  6. System.out.println(101);  
  7.  }  

 

好了,我們終于看到,mt實(shí)例對(duì)應(yīng)的線(xiàn)程(假如我有時(shí)說(shuō)mt線(xiàn)程請(qǐng)你不要怪我,不過(guò)我盡量不這么說(shuō))。在運(yùn)行完成后,主線(xiàn)程才打印101。因?yàn)槲覀冏尞?dāng)前線(xiàn)程(這里是主線(xiàn)程)等待mt線(xiàn)程的運(yùn)行結(jié)束。"在線(xiàn)程對(duì)象a上調(diào)用join()方法,就是讓當(dāng)前正在執(zhí)行的線(xiàn)程等待線(xiàn)程對(duì)象a對(duì)應(yīng)的線(xiàn)程運(yùn)行完成后才繼續(xù)運(yùn)行。" 請(qǐng)大家一定要深刻理解并熟記這句話(huà),而我這里引出這個(gè)知識(shí)點(diǎn)的目的是為了讓你繼續(xù)看下面的例子:

 

  1. public class Test {  
  2.  public static void main(String[] args) throws Exception{  
  3. MyThread mt = new MyThread();  
  4. mt.start();  
  5. mt.join();  
  6. Thread.sleep(3000);  
  7. mt.start();  
  8.  }  

 

當(dāng)線(xiàn)程對(duì)象mt運(yùn)行完成后,我們讓主線(xiàn)程休息一下,然后我們?cè)俅卧谶@個(gè)線(xiàn)程對(duì)象上啟動(dòng)線(xiàn)程。結(jié)果我們看到:

 

  1. Exception in thread "main" java.lang.IllegalThreadStateException 

 

也就是這種線(xiàn)程對(duì)象一時(shí)運(yùn)行一次完成后,它就再也不能運(yùn)行第二次了。我們可以看一下它有具體實(shí)現(xiàn):

 

  1. public synchronized void start() {  
  2.  if (started)  
  3. throw new IllegalThreadStateException();  
  4. started = true;  
  5. group.add(this);  
  6. start0();  
  7.  } 

 

一個(gè)Thread的實(shí)例一旦調(diào)用start()方法,這個(gè)實(shí)例的started標(biāo)記就標(biāo)記為true,事實(shí)中不管這個(gè)線(xiàn)程后來(lái)有沒(méi)有執(zhí)行到底,只要調(diào)用了一次start()就再也沒(méi)有機(jī)會(huì)運(yùn)行了,這意味著:

通過(guò)Thread實(shí)例的start(),一個(gè)Thread的實(shí)例只能產(chǎn)生一個(gè)線(xiàn)程

那么如果要在一個(gè)實(shí)例上產(chǎn)生多個(gè)線(xiàn)程(也就是我們常說(shuō)的線(xiàn)程池),我們應(yīng)該如何做呢?這就是Runnable接口給我們帶來(lái)的偉大的功能。

 

  1. class R implements Runnable{  
  2.  private int x = 0;  
  3.  public void run(){  
  4. for(int i=0;i<100;i++){  
  5.   try{  
  6. Thread.sleep(10);  
  7.   }catch(Exception e){}  
  8.   System.out.println(x++);  
  9. }  
  10.  }  

 

正如它的名字一樣,Runnable的實(shí)例是可運(yùn)行的,但它自己并不能直接運(yùn)行,它需要被Thread對(duì)象來(lái)包裝才行運(yùn)行:

 

  1. public class Test {  
  2.  public static void main(String[] args) throws Exception{  
  3. new Thread(new R()).start();  
  4.  }  

 

當(dāng)然這個(gè)結(jié)果和mt.start()沒(méi)有什么區(qū)別。但如果我們把一個(gè)Runnable實(shí)例給Thread對(duì)象多次包裝,我們就可以看到它們實(shí)際是在同一實(shí)例上啟動(dòng)線(xiàn)程:

 

  1. public class Test {  
  2.  public static void main(String[] args) throws Exception{  
  3. R r = new R();  
  4. for(int i=0;i<10;i++)  
  5.   new Thread(r).start();  
  6.  }  

 

x是實(shí)例對(duì)象,但結(jié)果是x被加到了999,說(shuō)明這10個(gè)線(xiàn)程是在同一個(gè)r對(duì)象上運(yùn)行的。請(qǐng)大家注意,因?yàn)檫@個(gè)例子是在單CPU上運(yùn)行的,所以沒(méi)有對(duì)多個(gè)線(xiàn)程同時(shí)操作共同的對(duì)象進(jìn)行同步。這里是為了說(shuō)明的方便而簡(jiǎn)化了同步,而真正的環(huán)境中你無(wú)法預(yù)知程序會(huì)在什么環(huán)境下運(yùn)行,所以一定要考慮同步。

到這里我們做一個(gè)完整的例子來(lái)說(shuō)明線(xiàn)程產(chǎn)生的方式不同而生成的線(xiàn)程的區(qū)別:

 

  1. package debug;  
  2. import java.io.*;  
  3. import java.lang.Thread;  
  4. class MyThread extends Thread{  
  5.  public int x = 0;  
  6.  public void run(){  
  7. System.out.println(++x);  
  8.  }  
  9. }  
  10. class R implements Runnable{  
  11.  private int x = 0;  
  12.  public void run(){  
  13. System.out.println(++x);  
  14.  }  
  15. }  
  16. public class Test {  
  17.  public static void main(String[] args) throws Exception{  
  18. for(int i=0;i<10;i++){  
  19.   Thread t = new MyThread();  
  20.   t.start();  
  21. }  
  22. Thread.sleep(10000);//讓上面的線(xiàn)程運(yùn)行完成  
  23. R r = new R();  
  24. for(int i=0;i<10;i++){  
  25.   Thread t = new Thread(r);  
  26.   t.start();  
  27. }  
  28.  }  

 

上面10個(gè)線(xiàn)程對(duì)象產(chǎn)生的10個(gè)線(xiàn)程運(yùn)行時(shí)打印了10次1。下面10個(gè)線(xiàn)程對(duì)象產(chǎn)生的10個(gè)線(xiàn)程運(yùn)行時(shí)打印了1到10。我們把下面的10個(gè)線(xiàn)程稱(chēng)為同一實(shí)例(Runnable實(shí)例)的多個(gè)線(xiàn)程。

【編輯推薦】

  1. Java多線(xiàn)程程序設(shè)計(jì)詳細(xì)解析
  2. Java多線(xiàn)程遞歸如何彌補(bǔ)管理漏洞
  3. Java多線(xiàn)程程序四步輕松學(xué)成
  4. Java多線(xiàn)程求和詳細(xì)學(xué)習(xí)筆記
  5. Java多線(xiàn)程進(jìn)程應(yīng)對(duì)同一程序運(yùn)行資源
責(zé)任編輯:于鐵 來(lái)源: ITWAKA.COM
相關(guān)推薦

2009-03-12 10:52:43

Java線(xiàn)程多線(xiàn)程

2023-06-07 13:49:00

多線(xiàn)程編程C#

2013-07-16 10:12:14

iOS多線(xiàn)程多線(xiàn)程概念多線(xiàn)程入門(mén)

2023-06-08 08:21:08

多線(xiàn)程編程線(xiàn)程間通信

2023-06-09 07:59:37

多線(xiàn)程編程鎖機(jī)制

2023-06-13 13:39:00

多線(xiàn)程異步編程

2017-03-08 14:18:37

Linux多線(xiàn)程編程

2018-10-25 15:55:44

Java多線(xiàn)程鎖優(yōu)化

2011-07-22 14:55:20

多線(xiàn)程

2009-02-24 08:36:51

多線(xiàn)程線(xiàn)程池網(wǎng)絡(luò)服務(wù)器

2009-07-29 16:42:35

Java多線(xiàn)程編程

2021-03-01 11:20:13

網(wǎng)絡(luò)安全多線(xiàn)程代碼

2023-06-05 07:56:10

線(xiàn)程分配處理器

2023-06-06 08:17:52

多線(xiàn)程編程Thread類(lèi)

2022-05-26 08:31:41

線(xiàn)程Java線(xiàn)程與進(jìn)程

2013-05-23 15:59:00

線(xiàn)程池

2023-05-12 14:14:00

Java線(xiàn)程中斷

2013-07-16 12:13:27

iOS多線(xiàn)程多線(xiàn)程概念GCD

2013-07-16 10:57:34

iOS多線(xiàn)程多線(xiàn)程概念多線(xiàn)程入門(mén)

2023-04-02 17:53:10

多線(xiàn)程編程自測(cè)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)