談?wù)凧ava中遍歷Map的幾種方法

java中的map遍歷有多種方法,從最早的Iterator,到j(luò)ava5支持的foreach,再到j(luò)ava8 Lambda,讓我們一起來看下具體的用法以及各自的優(yōu)缺點

先初始化一個map

keySet values

如果只需要map的key或者value,用map的keySet或values方法無疑是最方便的

keySet get(key)

如果需要同時獲取key和value,可以先獲取key,然后再通過map的get(key)獲取value

需要說明的是,該方法不是最優(yōu)選擇,一般不推薦使用

entrySet

通過對map entrySet的遍歷,也可以同時拿到key和value,一般情況下,性能上要優(yōu)于上一種,這一種也是最常用的遍歷方法

Lambda

java8提供了Lambda表達(dá)式支持,語法看起來更簡潔,可以同時拿到key和value,不過,經(jīng)測試,性能低于entrySet,所以更推薦用entrySet的方式

Iterator

對于上面的幾種foreach都可以用Iterator代替,其實foreach在java5中才被支持,foreach的寫法看起來更簡潔

但I(xiàn)terator也有其優(yōu)勢:在用foreach遍歷map時,如果改變其大小,會報錯,但如果只是刪除元素,可以使用Iterator的remove方法刪除元素

簡單性能測試

用10萬條數(shù)據(jù),做了一個簡單性能測試,數(shù)據(jù)類型為Integer,map實現(xiàn)選取HashMap

測試結(jié)果如下:

需要說明的是,map存儲的數(shù)據(jù)類型,map的大小,以及map的不同實現(xiàn)方式都會影響遍歷的性能,所以該測試結(jié)果僅供參考

總結(jié)

如果只是獲取key,或者value,推薦使用keySet或者values方式

如果同時需要key和value推薦使用entrySet

如果需要在遍歷過程中刪除元素推薦使用Iterator

如果需要在遍歷過程中增加元素,可以新建一個臨時map存放新增的元素,等遍歷完畢,再把臨時map放到原來的map中

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容