為啥要用HahSet?
假如我們現(xiàn)在想要在一大堆數(shù)據(jù)中查找X數(shù)據(jù)。LinkedList的數(shù)據(jù)結(jié)構(gòu)就不說(shuō)了,查找效率低的可怕。ArrayList哪,如果我們不知道X的位置序號(hào),還是一樣要全部遍歷一次直到查到結(jié)果,效率一樣可怕。HashSet天生就是為了提高查找效率的。
背景
上午剛到公司,準(zhǔn)備開(kāi)始一天的摸魚(yú)之旅時(shí)突然收到了一封監(jiān)控中心的郵件。
心中暗道不好,因?yàn)楸O(jiān)控系統(tǒng)從來(lái)不會(huì)告訴我應(yīng)用完美無(wú) bug,其實(shí)系統(tǒng)挺猥瑣。
打開(kāi)郵件一看,果然告知我有一個(gè)應(yīng)用的線程池隊(duì)列達(dá)到閾值觸發(fā)了報(bào)警。
由于這個(gè)應(yīng)用出問(wèn)題非常影響用戶體驗(yàn);于是立馬讓運(yùn)維保留現(xiàn)場(chǎng) dump 線程和內(nèi)存同時(shí)重啟應(yīng)用,還好重啟之后恢復(fù)正常。于是開(kāi)始著手排查問(wèn)題。
分析
首先了解下這個(gè)應(yīng)用大概是做什么的。
簡(jiǎn)單來(lái)說(shuō)就是從 MQ 中取出數(shù)據(jù)然后丟到后面的業(yè)務(wù)線程池中做具體的業(yè)務(wù)處理。
而報(bào)警的隊(duì)列正好就是這個(gè)線程池的隊(duì)列。
跟蹤代碼發(fā)現(xiàn)構(gòu)建線程池的方式如下:
ThreadPoolExecutor executor = new ThreadPoolExecutor(coreSize, maxSize, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue());; put(poolName,executor);