簡(jiǎn)介
概念:1.使用ThreadLocal維護(hù)變量會(huì)為每個(gè)使用該變量的線程提供獨(dú)立的變量副本,每個(gè)線程獨(dú)立改變副本不會(huì)影響其它線程的副本;
? ? ? ? ? ?2.ThreadLocal為解決多線程程序的并發(fā)問(wèn)題提供了一種新的思路,簡(jiǎn)潔優(yōu)美;
方法
void set(T value):設(shè)置當(dāng)前線程的線程局部變量的值;
T get():該方法返回當(dāng)前線程所對(duì)應(yīng)的線程局部變量;
void remove():將當(dāng)前線程局部變量的值刪除,目的是為了減少內(nèi)存的占用;
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? (線程結(jié)束gc會(huì)自動(dòng)回收,顯式調(diào)可以加快內(nèi)存回收)
T initialValue():返回該線程局部變量的初始值;(缺省值為null,一般使用匿名內(nèi)部類(lèi))
ThreadLocal與線程同步機(jī)制
都是為了解決多線程中相同變量的訪問(wèn)沖突問(wèn)題。
線程同步機(jī)制:1.通過(guò)對(duì)象的鎖機(jī)制保證同一時(shí)間只有一個(gè)線程訪問(wèn)變量;(變量是多個(gè)線程共享的,通過(guò)加鎖、釋放鎖)
? ? ? ? ? ? ? ? ? ? ? ? ?2.僅提供一份變量,讓不同的線程排隊(duì)訪問(wèn);
? ? ? ? ? ? ? ? ? ? ? ? ?3.鎖機(jī)制犧牲時(shí)間換空間;
ThreadLocal:1.為每一個(gè)線程提供一個(gè)獨(dú)立的變量副本,從而隔離了多個(gè)線程對(duì)數(shù)據(jù)的訪問(wèn)沖突;
? ? ? ? ? ? ? ? ? ? ? ? 2.為每一個(gè)線程都提供了一份變量,因此可以同時(shí)訪問(wèn)而互不影響;
? ? ? ? ? ? ? ? ? ? ? ? 3.存儲(chǔ)拷貝犧牲空間換時(shí)間;