我希望這個(gè)問題對(duì)于本論壇來說不是太基本了,但是我們會(huì)看到的。我想知道如何重構(gòu)一些代碼以獲得更好的性能,而這些性能已經(jīng)運(yùn)行了很多次。假設(shè)我正在使用地圖(可能是HashMap)創(chuàng)建一個(gè)單詞頻率列表,其中每個(gè)鍵是一個(gè)帶有要計(jì)算單詞的String,并且值是一個(gè)Integer,每次找到該單詞的標(biāo)記時(shí)都會(huì)增加。在Perl中,增加這樣的值非常容易:$map{$word}++;但是在Java中,它要復(fù)雜得多。這是我目前的操作方式:int count = map.containsKey(word) ? map.get(word) : 0;map.put(word, count + 1);當(dāng)然,哪個(gè)依賴于較新的Java版本中的自動(dòng)裝箱功能。我想知道您是否可以建議一種更有效的遞增此值的方法。避開Collections框架并改用其他東西,甚至有良好的性能原因嗎?更新:我已經(jīng)測(cè)試了幾個(gè)答案。見下文。
3 回答

慕運(yùn)維8079593
TA貢獻(xiàn)1876條經(jīng)驗(yàn) 獲得超5個(gè)贊
好的,可能是個(gè)老問題了,但是Java 8有一個(gè)更短的方法:
Map.merge(key, 1, Integer::sum)
它的作用:如果key不存在,則將1作為值,否則將1加到與key鏈接的值上。更多信息在這里
添加回答
舉報(bào)
0/150
提交
取消