您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關java中有哪些ThreadLocal核心方法,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
Java主要應用于:1. web開發;2. Android開發;3. 客戶端開發;4. 網頁開發;5. 企業級應用開發;6. Java大數據開發;7.游戲開發等。
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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。