天天看點

java-Thread筆記

生命周期

java-Thread筆記

相關方法

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 使用流程:

java-Thread筆記

TransmittableThreadLocal:可傳遞至子線程,子線程獨立操作,新開線程也會擷取新的值,需配合TtlRunnable或修改java啟動參數來使用

整個過程的官方完整時序圖:

java-Thread筆記

依據官方時序圖自己的整理:

java-Thread筆記