首頁  >  文章  >  Java  >  重拾java基礎(十七):多執行緒上總結

重拾java基礎(十七):多執行緒上總結

黄舟
黄舟原創
2017-01-16 10:27:13904瀏覽

重拾java基礎(十七):多執行緒上總結

一、進程

1. ctrl+shift+esc   任務管理器視窗2. 程式都在作業系統環境下運作的程式,需要佔用CPU和記憶體資源,從程式開始運行到程式被關閉,這個過程叫進程3.進程是作業系統中獨有的概念,進程=正在運行的程式4. 正在運行的程式都至少對應一個進程5. 有些程式會採用多進程架構設計7.進程間互相獨立,不能互相存取或共享資源

二、執行緒(thread)

1.程式-進程 工廠2. 工廠裡的生產線就叫執行緒3. 行程包含線程,執行緒是更小的一個獨立的執行單元4. 一個行程中可以包含一個執行緒(單執行緒),也可以包含多個執行緒(多執行緒)5. QQ是一個程式(行程) ,打開的每個聊天視窗就是一個線程6. 咱們之前寫的程式都是單線程,JVM會自動把main方法當成一個線程(生產線)去執行7. 線程不能獨立運行,不能脫離進程去執行,多個執行緒之間可以共用行程的資源8. 執行緒之間是獨立的

三、多執行緒程式設計

1. 咱們之前寫的程式都是單執行緒,JVM會自動把main方法當成一個執行緒(生產線)去執行2. 一個程式中有A/B兩個功能,如果採用多執行緒編程,A功能可以放到一個執行緒(生產線)執行,B功能可以放到一個執行緒(生產線)中執行3 . 上傳圖片  a.一張一張上傳  b.多張同時上傳4. 多執行緒是進一步利用了CPU和記憶體的資源,從而提供者的執行效率5. 工廠        迅雷

四、CPU跟多執行緒

1. 一個學生能同時寫字和看片嗎?大腦在寫字和看片之間切換2. 膠卷電影    速度非常快,大腦會產生錯覺3. 真正的「同時」是不存在的,CPU是在多個線程之間極快的、輪流的、隨機的進行切換

五、Java支援多執行緒

1.Java中有兩類執行緒:User Thread(使用者執行緒)、Daemon Thread(守護執行緒或後台服務執行緒) 。守護線程的作用是為其他線程的運行提供服務,比如說GC線程。 2.方式一:  繼承Thread類別    方式二:  實作Runnable介面

六、方式一

1. 我們之前定義的類別都是普通類,因為這些類別中的程式碼不能同時去執行,這些類別不是生產線類別2. Java專門提供了一個生產線類別:java.lang.Thread類別,該類別中的程式碼是可以同時執行的3. 步驟:        讓我們自訂的類別繼承Thread類,我們定義的類別就變成了生產線類       在自訂的類別中重寫run方法,把需要同時執行的程式碼放到run方法中       在main方法中,先造生產線,然後啟動生產線    start()

public long getId(),取得該執行緒的編號(執行緒ID) ,它在建立該執行緒時產生。線程 ID 是唯一的,並且終生不變。 public final void setName(String name),以執行緒命名,不命名的話語都有預設的,格式為:Thread-0、Thread-1...public final String getName(),取得執行緒的名字public void start() ,使該執行緒開始執行,JVM會自動呼叫該執行緒的run() 方法。 public static void sleep(long millis),讓線程休眠(暫停)多少毫秒public static Thread currentThread(),獲得目前正在執行的線程物件的參考。 (方式二會用到)


八、多執行緒的執行流程

1. JVM首先找到的是main方法,並把main中的程式碼放到一個執行緒執行,這個執行緒叫主執行緒2 . 另外自己人工創建的線程可以稱之為是子線程3. 程式必須等到所有的線程都執行完了,才會結束


九、方式二

1. 弊端:方式一繼承了Thread類後就不能繼承其他類別了 好處:簡單、容易實現2. 步驟:    a.我們自訂的類別實作java.lang.Runnable介面   b.把需要同時執行的程式碼放到run方法中   c.在main中建立生產線(Thread)並啟動3. 方式二沒有方式一的弊端,但是比方式一複雜


十、線程安全問題、

1. 什麼情況下會存在線程安全問題? a.多個執行緒之間是相互獨立的  b.多個執行緒在操作或使用共享資源2. 多個執行緒操作的是同一個共享資源,但是執行緒之間是彼此獨立、互不連結的,因此就會出現資料不同步更新的情況,這就是線程安全問題3. 賣火車票案例        同時要執行的代碼:賣10張火車票        共享資源:10張火車票     一般作為屬性存在

十一、怎麼解決線程安全問題

1. 思路:火車上的廁所,一個一個進......2. 同步鎖,專業術語叫監視器monitor3. Java在每個對像中都自動內建了一個監視器monitor   遍地都是鎖4. 有兩種實作方式:同步程式碼區塊    同步方法

十二、同步程式碼區塊

1. 先分析哪些程式碼需要上鎖2. synchronized(鎖){   }3. 多個執行緒之間使用的鎖必須是同一把鎖

十三、同步方法

1. 把需要上鎖的程式碼先放到一個方法中2. 把該方法變成同步方法public synchronized void sell(){     操作共享數據的代碼即需要同步的代碼;}3. 同步方法的鎖默認是this,是固定的

十四、同步鎖的利弊

同步的好處:       同步的出現解決了多執行緒的安全問題同步的弊端:    當執行緒相當多時,因為每個執行緒都會去判斷同步上的鎖,這是很耗費資源的,無形中會降低程式的運作效率。 (效能與執行緒安全不可兼得)

十五、細節問題

1. 靜態方法可以改為同步方法嗎? 可以  但是鎖不是this    載入類別的字節碼檔案     Student.class2. 執行緒安全問題出現的前提是:必須存在共享資源,而且多個執行緒使用了共享資源3. 鎖定必須是同一把鎖


以上就是重拾java基礎(十七):多執行緒上總結的內容,更多相關內容請關注PHP中文網(www.php.cn)!


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn