目錄:
線程狀態及流轉
鎖類型
關鍵字:synchronized、Lock、CAS、CountDownLatch、ReentrantLock、volatile、final、優先級、
單例模式中的雙重檢查
死鎖
線程通信
線程池
一些細節:在 線程/一些細節 里面
解決的實際問題:
各個平臺的特殊點:
RxJava-Android
協程-Kotlin
isolate-Flutter
線程和進程的區別
線程狀態及流轉
join流程
Java鎖類型
關鍵字:
synchronized、Lock、CAS、CountDownLatch、ReentrantLock、volatile、final、優先級、
單例模式中的雙重檢查 http://www.lxweimin.com/p/3b4f47c288ac
public class Singleton { private static volatile Singleton singletonInstance; // 靜態屬性,volatile保證可見性和禁止指令重排序 private Singleton () {} public static Singleton getInstance() { if(singletonInstance == null) { // 第一重檢查鎖定 synchronized(Singleton.class) // 同步鎖定代碼塊 if(singletonInstance == null) // 第二重檢查鎖定 singletonInstance = new Singleton (); // 注意:非原子操作 } return singletonInstance; } }
死鎖的四個條件:
互斥條件:一個資源每次只能被一個進程使用。
占有且等待:一個進程因請求資源而阻塞時,對已獲得的資源保持不放。
不可強行占有:進程已獲得的資源,在末使用完之前,不能強行剝奪。
循環等待條件:若干進程之間形成一種頭尾相接的循環等待資源關系。
這四個條件是死鎖的必要條件,只要系統發生死鎖,這些條件必然成立,而只要上述條件之一不滿足,就不會發生死鎖。
死鎖的解除與預防:
理解了死鎖的原因,尤其是產生死鎖的四個必要條件,就可以最大可能地避免、預防和解除死鎖。所以,在系統設計、進程調度等方面注意如何不讓這四個必要條件成立,如何確定資源的合理分配算法,避免進程永久占據系統資源。此外,也要防止進程在處于等待狀態的情況下占用資源。因此,對資源的分配要給予合理的規劃。
線程通信/同步:鎖解決
線程池 // TODO
CPU密集 vs IO密集:
CPU密集型任務應配置盡可能小的線程,如配置CPU數目個線程的線程池。
由于IO密集型任務線程并不是一直在執行任務,則應配置盡可能多的線程,如2*CPU數目。
1、FixedThreadPool
線程數固定的線程池,只有核心線程,不會回收空閑線程,任務隊列沒有大小限制。
2、CachedThreadPool
線程數量不定的線程池,只有非核心線程,最大線程數Integer.MAX_VALUE。如果沒有空閑線程就new,空閑線程超時60秒,超時被回收。
3、ScheduledThreadPool
核心線程固定,非核心線程Integer.MAX_VALUE,非核心線程空閑時立刻回收。主要用于執行定時任務和固定周期的重復任務。
4、SingleThreadExecutor
只有一個核心線程,所有任務按順序執行。
解決的實際問題:
線程池、interrupt終止線程、死鎖
各個平臺的特殊點:
RxJava-Android
協程-Kotlin
isolate-Flutter
Java 并發基礎之內存模型: https://javadoop.com/post/java-memory-model
重排序
內存可見性
原子性
Happens-before Order