本篇內容主要講解“java中ThreadLocal核心方法如何使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“java中ThreadLocal核心方法如何使用”吧!
創(chuàng)新互聯長期為近千家客戶提供的網站建設服務,團隊從業(yè)經驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯網生態(tài)環(huán)境。為肅南裕固族自治企業(yè)提供專業(yè)的網站建設、成都網站設計,肅南裕固族自治網站改版等技術服務。擁有10多年豐富建站經驗和眾多成功案例,為您定制開發(fā)。
1、get()方法
(1)獲取當前用的線程,并找到線程關聯的threadLocalMap
(2)threadLocalMap為空則進行初始化一個新的并返回
(3)threadLocalMap不為空則根據threadlocal作為key查找Entry
(4)若Entry不為空則返回entry對應的值,否則執(zhí)行第二條
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為空則創(chuàng)建,否則設置值進去 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為空,則觸發(fā)清理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核心方法如何使用”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!