您好,登錄后才能下訂單哦!
本篇內容主要講解“java中ThreadLocal核心方法如何使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。