Java HashMap 两种遍历方法性能比较

本文对比了通过keySet和entrySet两种不同方式遍历HashMap的效率,并通过具体实例展示了各自的执行时间,得出使用entrySet的方式更为高效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

	HashMap<String, Integer> map = new HashMap<>();

		map.put("1", 111);
		map.put("2", 222);
		map.put("3", 333);
		map.put("4", 444);
		map.put("5", 555);

		// This is the first way to get all the map element via Iterator with keySet.

		long startTime = System.nanoTime();
		Iterator it = map.keySet().iterator();
		while (it.hasNext()) {
			String key = (String) it.next();
			System.out.print(key + ", ");
			System.out.println(map.get(key));
		}
		long interval = System.nanoTime() - startTime;
		System.out.println("interval1: " + interval);
		
		// ======================================================================================================================

		// This is the second way to get all the map element via Entry

		long startTime2 = System.nanoTime();
		Set<Entry<String, Integer>> sets = map.entrySet();
		for (Entry<String, Integer> entry : sets) {
			System.out.print(entry.getKey() + ", ");
			System.out.println(entry.getValue());
		}
		long interval2 = System.nanoTime() - startTime2;
		System.out.println("interval2: " + interval2);

First way result:

3, 333

2, 222
1, 111
5, 555
4, 444

interval1: 1152533

Second way result:

3, 333
2, 222
1, 111
5, 555
4, 444
interval2: 521673


It is obvious that the second way with EntrySet is better than the first one with keySet!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值