Java性能优化:遍历

说说本身踩到的坑

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

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迭代器。code

另外,还可使用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异常,因此要根据具体操做选取。rem