java中的map遍歷有多種方法,從最早的Iterator,到j(luò)ava5支持的foreach,再到j(luò)ava8 Lambda,下面讓上海Java培訓(xùn)機(jī)構(gòu)談?wù)凪ap具體的用法以及各自的優(yōu)缺點(diǎn)
先初始化一個(gè)map
keySet values
如果只需要map的key或者value,用map的keySet或values方法無(wú)疑是最方便的
keySet get(key)
如果需要同時(shí)獲取key和value,可以先獲取key,然后再通過(guò)map的get(key)獲取value
需要說(shuō)明的是,該方法不是最優(yōu)選擇,一般不推薦使用
entrySet
通過(guò)對(duì)map entrySet的遍歷,也可以同時(shí)拿到key和value,一般情況下,性能上要優(yōu)于上一種,這一種也是最常用的遍歷方法
Iterator
對(duì)于上面的幾種foreach都可以用Iterator代替,其實(shí)foreach在java5中才被支持,foreach的寫(xiě)法看起來(lái)更簡(jiǎn)潔
但I(xiàn)terator也有其優(yōu)勢(shì):在用foreach遍歷map時(shí),如果改變其大小,會(huì)報(bào)錯(cuò),但如果只是刪除元素,可以使用Iterator的remove方法刪除元素
Lambda
java8提供了Lambda表達(dá)式支持,語(yǔ)法看起來(lái)更簡(jiǎn)潔,可以同時(shí)拿到key和value,不過(guò),經(jīng)測(cè)試,性能低于entrySet,所以更推薦用entrySet的方式
簡(jiǎn)單性能測(cè)試
用10萬(wàn)條數(shù)據(jù),做了一個(gè)簡(jiǎn)單性能測(cè)試,數(shù)據(jù)類(lèi)型為Integer,map實(shí)現(xiàn)選取HashMap
測(cè)試結(jié)果如下:
需要說(shuō)明的是,map存儲(chǔ)的數(shù)據(jù)類(lèi)型,map的大小,以及map的不同實(shí)現(xiàn)方式都會(huì)影響遍歷的性能,所以該測(cè)試結(jié)果僅供參考
總結(jié)
如果只是獲取key,或者value,推薦使用keySet或者values方式
如果同時(shí)需要key和value推薦使用entrySet
如果需要在遍歷過(guò)程中刪除元素推薦使用Iterator
如果需要在遍歷過(guò)程中增加元素,可以新建一個(gè)臨時(shí)map存放新增的元素,等遍歷完畢,再把臨時(shí)map放到原來(lái)的map中。
以上就是上海Java培訓(xùn)http://sh.lanou3g.com/談?wù)凧ava中遍歷Map的幾種方法
請(qǐng)?zhí)顚?xiě)留言或根據(jù)意向選擇下列快捷留言
負(fù)責(zé)聲明:以上所展示的信息由會(huì)員自行提供,內(nèi)容真實(shí)性,準(zhǔn)確性和合法性由發(fā)布會(huì)與負(fù)責(zé)。本網(wǎng)對(duì)此不承擔(dān)任何責(zé)任。
友情提醒:為規(guī)避投資風(fēng)險(xiǎn),建議您在投資前務(wù)必多咨詢(xún),多考察,降低投資風(fēng)險(xiǎn)。