您好,登錄后才能下訂單哦!
本篇內容介紹了“java中ThreadLocal核心方法怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
1、get()方法
(1)獲取當前用的線程,并找到線程關聯的threadLocalMap
(2)threadLocalMap為空則進行初始化一個新的并返回
(3)threadLocalMap不為空則根據threadlocal作為key查找Entry
(4)若Entry不為空則返回entry對應的值,否則執行第二條
public T get() { // 獲取當前線程 Thread t = Thread.currentThread(); ThreadLocalMap map = getMap(t); //若當前線程關聯的ThreadLocal不為空則查詢 if (map != null) { //根據threadLocal查詢對應的Entry ThreadLocalMap.Entry e = map.getEntry(this); if (e != null) { @SuppressWarnings("unchecked") T result = (T)e.value; return result; } } return setInitialValue(); } private T setInitialValue() { //默認返回null值 T value = initialValue(); Thread t = Thread.currentThread(); ThreadLocalMap map = getMap(t); //如果當前調用線程關聯的ThreadLocalMap為空則創建,否則設置值進去 if (map != null) map.set(this, value); else //new ThreadLocalMap(this,value) createMap(t, value); return value; } private Entry getEntry(ThreadLocal<?> key) { //根據key獲取其在數組的下標位置 int i = key.threadLocalHashCode & (table.length - 1); Entry e = table[i]; if (e != null && e.get() == key) return e; else return getEntryAfterMiss(key, i, e); } private Entry getEntryAfterMiss(ThreadLocal<?> key, int i, Entry e) { Entry[] tab = table; int len = tab.length; //數組下標的Entry不為空且關聯的threadlocal與查找的threadlocal不一致 while (e != null) { ThreadLocal<?> k = e.get(); //entry關聯的threadlocal與查找的相等則直接返回 if (k == key) return e; if (k == null) //關聯的threadlocal為空,則觸發清理key為null的Entry并重新進行rehash舊Entry數組的元素 //threadLocalMap的hash沖突與hashMap的沖突處理方式不一致,hashMap使用的是鏈表地址法, //而threadLocalMap使用的開放地址法——線性探測,即順序查找下一位置或者遍歷全表,效率較低 expungeStaleEntry(i); else //遞增下標i的值進行下一輪的查找 i = nextIndex(i, len); e = tab[i]; } return null; }
2、remove()方法
(1)獲取當前用的線程,并找到線程關聯的threadLocalMap
(2)若不為空則刪除threadLocalMap中關聯的值,否則啥也不做
//ThreadLocal public void remove() { ThreadLocalMap m = getMap(Thread.currentThread()); if (m != null) //刪除當前threadLocal對象關聯的Entry m.remove(this); } //ThreadLocalMap private void remove(ThreadLocal<?> key) { Entry[] tab = table; int len = tab.length; int i = key.threadLocalHashCode & (len-1); for (Entry e = tab[i]; e != null; e = tab[i = nextIndex(i, len)]) { if (e.get() == key) { e.clear(); expungeStaleEntry(i); return; } } }
“java中ThreadLocal核心方法怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。