好程序員Java學習路線分享多線程概念

  好程序員Java學習路線分享多線程概念

  1、進程:正在執行中的程序,其實是應用程序在內存中運行的那片空間。

 

  2、線程:進程中的一個執行單元,負責進程中的程序的運行,一個進程中至少要有一個線程。一個進程中可以有多個線程的,這個應用程序也可以稱之爲多線程程序。

 

  3、程序啓動多線程,有什麼應用呢?可以實現多個程序同時執行,專業術語稱爲併發。多線程的使用可以合理使用cpu的資源,如果線程過多導致降低性能。

 

  4、創建線程的方式兩種方式:

 

  4.1、繼承Thread

 

  4.1.1、定義一個類繼承Thread

 

  4.1.2、重寫run方法

 

  4.1.3、創建子類對象

 

  4.1.4、啓動start方法

 

  4.2、實現Runnable

 

  4.2.1、定義類實現runnable接口

 

  4.2.2、覆蓋接口中run方法,將線程任務代碼定義到run方法裏。

 

  4.2.3、創建Thread類的對象。

 

  4.2.4、將runnable接口的子類對象作爲參數傳入Thread類的構造方法裏。

 

  4.2.5、啓用Thread類的start方法。

 

  5、線程對象調用run方法和調用start方法區別?調用run方法不開啓線程,近視對象調用方法。調用start方法開啓線程,並讓JVM調用run方法在開啓的線程中執行。

 

  6、創建線程的目的是什麼?是爲了建立單獨的執行路徑,讓多部分代碼實現同時執行。也就是線程創建並執行需要給定的代碼(線程任務)

 

  7、多線程執行時,在棧內存中,其實每一個執行線程都有一片自己所屬的棧內存空間。進行方法的壓棧和彈棧。當執行線程的任務結束了,線程自動在棧內存中釋放了。但是當所有的執行線程都結束了,那麼進程就結束了。

 

  8ThreadRunnable的區別Runnable接口避免了單繼承的侷限性。實現Runnable接口的方式,更加符合面向對象,線程分爲兩部分,一部分線程對象,一部分線程任務。繼承Thread類:線程對象和線程任務耦合在一起。一旦創建Thread類的子類對象,既是線程對象,又有線程任務。將線程任務單獨分離出來封裝成對象,類型就是runnable接口類型。實現Runnable接口對線程對象和線程任務進行解耦。

 

  9、線程的運行狀態被創建:運行:該狀態是線程具備了CPU執行資格的同時也具備了執行權,一個時刻只能有一個線程在執行。消亡:當run方法結束,線程就進入了消亡狀態。凍結:釋放了CPU的執行權和執行資格,有兩種方式:sieep(休眠)wait(等待),同時也有兩種方式解除此狀態,sleep(時間到)notify()要注意的時,當線程從凍結狀態結束後,並沒有立馬運行,只能說它獲取了CPU的執行資格,因爲隨機性的原因,它也可能轉換成臨時阻塞狀態。臨時阻塞狀態:線程具備CPU的執行資格,不具備執行權,正等着CPU切換到它運行。

  10、多線程的安全性問題的原因

 

  10.1多個線程在操作共享的數據。

 

  10.2線程任務操作共享數據的代碼有多條(運算有多個)。解決問題:用同步代碼塊synchronized同步的好處:解決多線程的安全問題。同步的弊端:降低了程序的性能。同步的前提:必須保證多個線程在同步中使用的是同一個鎖。同步的另一種體現形式:同步函數。同步函數使用的鎖是this

 

  11、多線程安全問題-同步函數使用的鎖和同步代碼塊的區別同步函數使用的鎖是固定的this。同步代碼塊使用的鎖可以是任意對象。

 

  12、靜態同步函數使用的鎖不是this,而是字節碼文件對象類名.class

 

  13、單例設計模式13.1惡漢式:

 

  代碼體現:

 

  ClassSingle{

 

  PrivtaestaticfinalSingles=newSingle();

 

  PrivateSingle(){}

 

  PublicstaticSinglegetInstance(){

 

  Returns;}

 

  }

 

  13.2、懶漢式:延遲加載,存在着多線程併發訪問的安全問題,需要使用同步來解決安全問題,但是同步會降低效率,所以使用雙重if()判斷形式解決效率低的問題。

 

  實現代碼:ClassSingle{

 

  PrivateSingle(){}

 

  PrivatestaticSingles=null;

 

  PublicstaticSinglegetInstance(){

 

  If(s==null){

 

  Synchroinzed(Single.class){

 

  If(s==null)S=newSingle();

 

  }Returns;}

 

  }

 

  }

 

  14、死鎖:即同步的弊端,不是線程和進程沒有了,而是不動了。表現形式:同步嵌套的時候,使用的鎖不一樣,容易引發死鎖。

 

  實現代碼:

 

  //Thread-0

 

  Synchroinzed(obj1){Synchroinzed(obj2){}}

 

  //Thread-1

 

  Synchroinzed(obj2){Synchroinzed(obj1){}}

  


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章