目錄:
線程狀態(tài)及流轉(zhuǎn)
鎖類型
關鍵字:synchronized证薇、Lock、CAS效拭、CountDownLatch暂吉、ReentrantLock、volatile允耿、final借笙、優(yōu)先級、
單例模式中的雙重檢查
死鎖
線程通信
線程池
一些細節(jié):在 線程/一些細節(jié) 里面
解決的實際問題:
各個平臺的特殊點:
RxJava-Android
協(xié)程-Kotlin
isolate-Flutter
線程和進程的區(qū)別
線程狀態(tài)及流轉(zhuǎn)
join流程
Java鎖類型
關鍵字:
synchronized较锡、Lock业稼、CAS、CountDownLatch蚂蕴、ReentrantLock低散、volatile、final骡楼、優(yōu)先級熔号、
單例模式中的雙重檢查 http://www.reibang.com/p/3b4f47c288ac
public class Singleton { private static volatile Singleton singletonInstance; // 靜態(tài)屬性,volatile保證可見性和禁止指令重排序 private Singleton () {} public static Singleton getInstance() { if(singletonInstance == null) { // 第一重檢查鎖定 synchronized(Singleton.class) // 同步鎖定代碼塊 if(singletonInstance == null) // 第二重檢查鎖定 singletonInstance = new Singleton (); // 注意:非原子操作 } return singletonInstance; } }
死鎖的四個條件:
互斥條件:一個資源每次只能被一個進程使用鸟整。
占有且等待:一個進程因請求資源而阻塞時引镊,對已獲得的資源保持不放。
不可強行占有:進程已獲得的資源,在末使用完之前弟头,不能強行剝奪吩抓。
循環(huán)等待條件:若干進程之間形成一種頭尾相接的循環(huán)等待資源關系。
這四個條件是死鎖的必要條件赴恨,只要系統(tǒng)發(fā)生死鎖疹娶,這些條件必然成立,而只要上述條件之一不滿足伦连,就不會發(fā)生死鎖雨饺。
死鎖的解除與預防:
理解了死鎖的原因,尤其是產(chǎn)生死鎖的四個必要條件惑淳,就可以最大可能地避免额港、預防和解除死鎖。所以汛聚,在系統(tǒng)設計锹安、進程調(diào)度等方面注意如何不讓這四個必要條件成立,如何確定資源的合理分配算法倚舀,避免進程永久占據(jù)系統(tǒng)資源。此外忍宋,也要防止進程在處于等待狀態(tài)的情況下占用資源痕貌。因此,對資源的分配要給予合理的規(guī)劃糠排。
線程通信/同步:鎖解決
線程池 // TODO
CPU密集 vs IO密集:
CPU密集型任務應配置盡可能小的線程舵稠,如配置CPU數(shù)目個線程的線程池。
由于IO密集型任務線程并不是一直在執(zhí)行任務入宦,則應配置盡可能多的線程哺徊,如2*CPU數(shù)目。
1乾闰、FixedThreadPool
線程數(shù)固定的線程池落追,只有核心線程,不會回收空閑線程涯肩,任務隊列沒有大小限制轿钠。
2、CachedThreadPool
線程數(shù)量不定的線程池病苗,只有非核心線程疗垛,最大線程數(shù)Integer.MAX_VALUE。如果沒有空閑線程就new硫朦,空閑線程超時60秒贷腕,超時被回收。
3、ScheduledThreadPool
核心線程固定泽裳,非核心線程Integer.MAX_VALUE芽世,非核心線程空閑時立刻回收。主要用于執(zhí)行定時任務和固定周期的重復任務诡壁。
4济瓢、SingleThreadExecutor
只有一個核心線程,所有任務按順序執(zhí)行妹卿。
解決的實際問題:
線程池旺矾、interrupt終止線程、死鎖
各個平臺的特殊點:
RxJava-Android
協(xié)程-Kotlin
isolate-Flutter
Java 并發(fā)基礎之內(nèi)存模型: https://javadoop.com/post/java-memory-model
重排序
內(nèi)存可見性
原子性
Happens-before Order