Map 集合遍历的5种方法,收藏备用

Map 集合遍历的5种方法,收藏备用Map<String, String> map = new HashMap<String, String>

大家好,欢迎来到IT知识分享网。

Map 集合遍历的5种方法,收藏备用

最好的语言

Map 集合初始化时,指定集合初始值大小。 说明:HashMap 使用 HashMap(int initialCapacity) 初始化。 正例:initialCapacity = (需要存储的元素个数 / 负载因子) + 1。注意负载因子(即 loaderfactor)默认为 0.75,如果暂时无法确定初始值大小,请设置为 16(即默认值)。 反例:HashMap 需要放置 1024 个元素,由于没有设置容量初始大小,随着元素不断增加,容量 7 次被迫扩大,resize 需要重建 hash 表,严重影响性能。 public class ForeachMap { public static void main(String[] args) { Map<String, String> map = new HashMap<String, String>(); map.put("李白", "青莲居士"); map.put("杜甫", "少陵野老"); map.put("白居易", "香山居士"); //第一种:普遍使用,二次取值 System.out.println("通过Map.keySet遍历key和value"); for (String key : map.keySet()) { System.out.println("key= "+ key + " and value= " + map.get(key)); } //第二种:使用iterator System.out.println("通过Map.entrySet使用iterator遍历key和value"); Iterator<Map.Entry<String, String>> it = map.entrySet().iterator(); while (it.hasNext()) { Map.Entry<String, String> entry = it.next(); System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue()); } //第三种:推荐,尤其是容量大时 System.out.println("通过Map.entrySet遍历key和value"); for (Map.Entry<String, String> entry : map.entrySet()) { System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue()); } //第四种:Map.values() System.out.println("通过Map.values()遍历所有的value,但不能遍历key"); for (String v : map.values()) { System.out.println("value= " + v); } //第五种:map.forEach System.out.println("map.forEach JDK1.8 新特性"); map.forEach((key, value) -> { System.out.println("key=" + key + ",value=" + value); }); } 运行结果: 通过Map.keySet遍历key和value key= 李白 and value= 青莲居士 key= 杜甫 and value= 少陵野老 key= 白居易 and value= 香山居士 通过Map.entrySet使用iterator遍历key和value key= 李白 and value= 青莲居士 key= 杜甫 and value= 少陵野老 key= 白居易 and value= 香山居士 通过Map.entrySet遍历key和value key= 李白 and value= 青莲居士 key= 杜甫 and value= 少陵野老 key= 白居易 and value= 香山居士 通过Map.values()遍历所有的value,但不能遍历key value= 青莲居士 value= 少陵野老 value= 香山居士 map.forEach JDK1.8 新特性 key=李白,value=青莲居士 key=杜甫,value=少陵野老 key=白居易,value=香山居士 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/48675.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信