java 線程 進程

來源:互聯網
上載者:User

標籤:tool   public   icon   tac   java   []   方法   複雜   while   

 Java多線程(一)、多線程的基本概念和使用2012-09-10 16:06 5108人閱讀 評論(0) 收藏 舉報 分類:javaSE綜合知識點(14) 

著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

 

一、進程和線程的基礎知識

1、進程和線程的概念

進程:運行中的應用程式稱為進程,擁有系統資源(cpu、記憶體)

線程:進程中的一段代碼,一個進程中可以有多段代碼。本身不擁有資源(共用所在進程的資源)

在Java中,程式入口被自動建立為主線程,在主線程中可以建立多個子線程。

區別:

 1、是否佔有資源問題

 2、建立或撤銷一個進程所需要的開銷比建立或撤銷一個線程所需要的開銷大。

 3、進程為重量級組件,線程為輕量級組件

 

多進程: 在作業系統中能同時運行多個任務(程式)

多線程: 在同一應用程式中有多個功能流同時執行

 

2、線程的主要特點

①、不能以一個檔案名稱的方式獨立存在在磁碟中;

②、不能單獨執行,只有在進程啟動後才可啟動;

③、線程可以共用進程相同的記憶體(代碼與資料)。

 

3、線程的主要用途

①、利用它可以完成重複性的工作(如實現動畫、聲音等的播放)。

②、從事一次性較費時的初始化工作(如網路連接、聲音資料檔案的載入)。

③、並發執行的運行效果(一個進程多個線程)以實現更複雜的功能

 

4、多線程(多個線程同時運行)程式的主要優點

①、可以減輕系統效能方面的瓶頸,因為可以並行操作;

②、提高CPU的處理器的效率,在多線程中,通過優先順序管理,可以使重要的程式優先操作,提高了任務管理的靈活性;另一方面,在多CPU系統中,可以把不同的線程在不同的CPU中執行,真正做到同時處理多任務。

 

 

二、線程的建立和啟動

其實看看API,從Thread的構造方法,就可以看出建立一個線程的方式:

Thread()
          分配新的 Thread 對象。
Thread(Runnable target)
          分配新的 Thread 對象。
Thread(Runnable target,String name)
          分配新的 Thread 對象。
Thread(String name)
          分配新的 Thread 對象。
Thread(ThreadGroup group,Runnable target)
          分配新的 Thread 對象。
Thread(ThreadGroup group,Runnable target,String name)
          分配新的 Thread 對象,以便將 target 作為其運行對象,將指定的 name 作為其名稱,並作為 group 所引用的線程組的一員。
Thread(ThreadGroup group,Runnable target,String name, long stackSize)
          分配新的 Thread 對象,以便將 target 作為其運行對象,將指定的 name 作為其名稱,作為 group 所引用的線程組的一員,並具有指定的堆棧大小
Thread(ThreadGroup group,String name)
          分配新的 Thread 對象。

 

後面4個構造方法建立一個線程並加入到一個線程組中,但是建立線程的方式和前面的相似。

java中建立一個線程有兩種方式:

1、繼承Thread類,重寫run()方法,然後直接new這個對象的執行個體,建立一個線程的執行個體。然後調用start()方法啟動線程

2、實現Runnable介面,重寫run()方法,然後調用new Thread(runnable)的方式建立一個線程,然後調用start()方法啟動線程

其實看Thread的源檔案,發現它也是實現了Runnable介面的。

 

[java] view plain copy 
  1. public class Thread implements Runnable   

1、繼承Thread類的方式

 

 

[java] view plain copy 
  1. public class Test1 {  
  2.     public static void main(String[] args) {  
  3.         System.out.println(Thread.currentThread().getName());  
  4.         MyThread myThread=new MyThread();  
  5.         myThread.start();  
  6.     }  
  7. }  
  8. class MyThread extends Thread{  
  9.     int i=0;  
  10.     @Override  
  11.     public void run() {  
  12.         while (i<10) {  
  13.             System.out.println(this.getName()+"    i的值   "+i);  
  14.             i++;  
  15.         }  
  16.     }  
  17. }  

2、實現Runnable介面

 

 

[java] view plain copy 
  1. public class Test1 {  
  2.     public static void main(String[] args) {  
  3.         System.out.println(Thread.currentThread().getName());  
  4.         Thread thread=new Thread(new MyRunnable());  
  5.         thread.start();  
  6.     }  
  7. }  
  8. class MyRunnable implements Runnable{  
  9.     int i=0;  
  10.     @Override  
  11.     public void run() {  
  12.         while (i<10) {  
  13.             System.out.println(Thread.currentThread().getName()+"    i的值   "+i);  
  14.             i++;  
  15.         }  
  16.     }  
  17. }  

注意:

 

①、在繼承Thread的方式中,可以使用getName()方法,來獲得當前線程的名字,這是因為在Thread類中,有這個方法。可是在實現Runnable方式中,卻不可以使用this.getName(),因為Runnable介面沒有這個方法(可以看出來,因為我們沒有提示我們需要重寫這個方法),所以只能通過Thread的靜態方法Thread.currentThread()取得當前的Thread對象,在調用getName()方法,來取得當前線程的名字。

②、對Java來說,run()方法沒有任何特別之處。像main()方法一樣,它只是新線程知道調用的方法名稱(和簽名)。因此,在Runnable上或者Thread上調用run方法是合法的。但並不啟動新的線程。只有調用start()方法才會啟動新線程。

3、兩種方式的對比

採用實現Runnable介面方式的多線程具有優勢,一般都會使用這種方式:

1、線程類只是實現了Runnable介面,還可以繼承其他類。

2、在這種方式下,可以多個線程共用一個Runnable target對象,所以非常適合多個相同線程來處理同一份資源的情況,從而可以將CPU、代碼和資料分開,形成清晰的模型,較好的體現了物件導向的思想。

java 線程 進程

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.