生命周期

相關方法
interrupt():執行個體方法将線程中斷辨別設定為true,如線程在wait/sleep則報java.lang.InterruptedException
interrupted():靜态方法,Thread.interrupted()重置目前線程中斷辨別
isInterrupted(): 執行個體方法擷取目前線程中斷辨別
join():中斷目前線程,等待調用線程結束後再執行
Thread.sleep(millis):目前線程休眠x毫秒,不釋放持有鎖
LockSupport.park():中斷目前線程,不釋放持有鎖
Object.wait(millis):目前線程等待x秒,不傳遞則無限期等待,釋放持有鎖
線程變量
ThreadLocal:同線程内共享,無法傳遞至子線程
生命周期:在設定第一個值時通過Thread.currentThread()與目前線程中threadLocals進行關聯,并初始化一個ThreadLocalMap進行存儲。
ThreadLocalMap中存儲内容的Entry使用的是WeakReference弱引用,便于垃圾回收。
- 在非線程池情況下由于key為弱引用在代碼中沒有繼續使用時(強引用去掉後隻剩弱引用),會被gc回收.get方法會清理不存在的key對應的value,保障了記憶體回收
- 線上程池中使用時由于線程不會被回收,Thread這個強引用不會被清理,是以存在記憶體溢出風險。 可在使用完成之後通過remove方法清理來規避這個隐患。
- 使用static初始化時也存在生命周期過長存在記憶體溢出隐患
InheritableThreadLocal:隻有在建立線程池時會初始化,是以線程池場景會導緻指派邏輯混亂
重寫了childValue(),getMap(Thread),createMap(Thread t, T firstValue) 來實作子線程的内容指派
ThreadLocal/InheritableThreadLocal 使用流程:
TransmittableThreadLocal:可傳遞至子線程,子線程獨立操作,新開線程也會擷取新的值,需配合TtlRunnable或修改java啟動參數來使用
整個過程的官方完整時序圖:
依據官方時序圖自己的整理: