Java性能优化:遍历

说说自己踩到的坑

某个项目中遍历一个List集合,该集合比较大,大概有几万条数据,我使用了for循环遍历:

public void readList(List<String> list) {
	if (list != null) {
		for (int i=0; i<list.size(); i++) {
			// do something...
		}
	}
}

做测试的时候发现程序执行特别慢,找了好久找到了原因,就是上面的方法中的问题:由于方法参数中给定的List集合可能是ArrayList,也可能是LinkedList。当遍历LinkedList的时候,如果集合很大,会出现程序执行效率慢的问题。

将上面的方法重构:

public void readList(List<String> list) {
	if (list != null) {
		Itarator<String> iter = list.iterator():
		while (iter.hasNext()) {
			// do something...
		}
	}
}

重构后程序执行确实快了不少,这源于ArrayListLinkedList内部实现的区别,LinkedList随机读取要比ArrayList慢,关于ArrayListLinkedList区别不多说了,其他网站有很多异同点的比较。

总结一下

除非遍历的过程中要获取集合中元素的索引使用for循环,否则遍历集合尽量使用Iterator迭代器。

另外,还可以使用forEach循环:

public void readList(List<String> list) {
	if (list != null) {
		for (String str : list) {
			// do something...
		}
	}
}

forEach循环是Iterator写法的简化版,也不用担心数组越界,它的内部实现也是使用Iterator迭代器(可以通过反编译后查看)。不过功能上没有Iterator强大,比如在forEach调用集合的remove()方法会导致java.util.ConcurrentModificationException异常,所以要根据具体操作选取。

转载于:https://my.oschina.net/lw900925/blog/707141

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值