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中