在java开发中,hashmap是非常重要的容器类,存储的是键值对(key,value)。
hashmap继承abstractmap,实现了map、cloneable、serializable接口,非线程安全类,但是效率高。hashmap允许null健和null值,允许value重复,但不允许key重复。hashmap有两个参数影响其性能,初始容量和加载因子,当哈希表中的条目数超出加载因子与当前容量的乘积时,要对哈希表进行refresh操作,重建内部数据结构,容量扩大为之前的两倍,加载因子默认值为0.75。
hashmap的遍历方式
第一种,遍历hashmap的entryset键值对集合,通过hashmap.entryset()得到键值对集合,通过迭代器iterator遍历集合得到key和value。
public static void main(string[] args) { map<object, object> map = new hashmap<>(); map.put("caocao","11"); map.put("liubei","22"); map.put("sunquan","33"); first(map); } private static void first(map<object, object> map) { iterator<map.entry<object, object>> iterator = map.entryset().iterator(); while (iterator.hasnext()) { map.entry<object, object> entry = iterator.next(); system.out.println("key:" + entry.getkey() + ",vaule:" + entry.getvalue()); } }
第二种,遍历hashmap的keyset集合,通过hashmap.keyset()得到key集合,通过迭代器iterator遍历集合得到key和value。
private static void second(map<object, object> map) { iterator<object> iterator = map.keyset().iterator(); while (iterator.hasnext()) { object key = iterator.next(); system.out.println("key:" + key + ",vaule:" + map.get(key)); } }
第三种,遍历hashmap的values集合,通过hashmap.valus()得到value集合,通过迭代器iterator遍历集合得到key和value。
private static void third(map<object, object> map) { iterator<object> iterator = map.values().iterator(); while (iterator.hasnext()) { object value = iterator.next(); system.out.println("vaule:" + value); } }
第四种,遍历hashmap的entryset键值对集合,通过hashmap.entryset()得到键值对集合,通过for循环遍历集合得到key和value。
private static void fourth(map<object, object> map) { for (map.entry<object,object> entry: map.entryset()) { system.out.println("key:" + entry.getkey() + ",vaule:" + entry.getvalue()); } }
第五种,遍历hashmap的keyset集合,通过hashmap.keyset()得到key集合,通过for循环遍历集合得到key和value。
private static void fifth(map<object, object> map) { for(object key : map.keyset()) { system.out.println("key:" + key + ",vaule:" + map.get(key)); } }
第六种,遍历hashmap的values集合,通过hashmap.valus()得到value集合,通过for循环遍历集合得到key和value。
private static void sixth(map<object, object> map) { for (object value : map.values()) { system.out.println("vaule:" + value); } }
第七种,通过lambda遍历hashmap得到key和value
private static void seventh(map<object, object> map) { map.foreach((key,value) -> { system.out.println("key:" + key + ",vaule:" + value); }); }
第八种,通过lambda遍历hashmap.entryset()得到键值对集合得到key和value
private static void eighth(map<object, object> map) { map.entryset().foreach(item -> { system.out.println("key:" + item.getkey() + ",vaule:" + item.getvalue()); }); }
第九种,通过lambda遍历hashmap.keyset()得到key集合得到key和value
private static void ninth(map<object, object> map) { map.keyset().foreach(item -> { system.out.println("key:" + item + ",vaule:" + map.get(item)); }); }
以上遍历主要iterator遍历集合方式、for循环遍历集合方式,lambda遍历集合方式,根据具体需求选用不同的方式,通过iterator方式循环删除数据是安全的,for方式循环删除数据非安全,lambda方式循环删除数据非安全,通过iterator方式的效率也很高。
到此这篇关于java中hashmap遍历的9种方式的文章就介绍到这了,更多相关java hashmap遍历内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论