最好的语言
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=香山居士
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。