今天小编给大家分享一下java迭代器和for循环优劣势是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
1.概念理解
for循环:是支持迭代的一种通用结构,是最有效,最灵活的循环结构
迭代器:是通过集合的iterator()方法得到的,所以我们说它是依赖于集合而存在的
Foreach:通过阅读源码我们还发现一个Iterable接口。它包含了一个产生Iterator对象的iterator()方法,而且将Iterator对象被foreach用来在序列中移动。对于任何实现Iterable接口的对象都可以使用。
2.效率实例
ArrayList中的效率对比:
List<Integer> integers = Lists.newArrayList();
for(int i=0;i<100000;i++){
integers.add(i);
}
long start1 = System.currentTimeMillis();
for(int count =0 ;count<10;count++){
for(int i=0;i<integers.size();i++){
int j=integers.get(i);
}
}
System.out.println(String.format("for循环100次时间:%s ms",System.currentTimeMillis()-start1));
long start2 = System.currentTimeMillis();
for(int count =0 ;count<10;count++) {
for (Integer i : integers) {
int j = i;
}
}
System.out.println(String.format("foreach循环100次时间:%s ms",System.currentTimeMillis()-start2));
long start3 = System.currentTimeMillis();
for(int count =0 ;count<10;count++) {
Iterator<Integer> iterator = integers.iterator();
while(iterator.hasNext()){
int j=iterator.next();
}
}
System.out.println(String.format("迭代器循环100次时间:%s ms",System.currentTimeMillis()-start3));
结果:
for循环100次时间:15 ms
foreach循环100次时间:25 ms
迭代器循环100次时间:20 ms
ArrayList下三者效率差不多,for循环最优,因为ArrayList通过数组来实现,数组通过索引来定位的时间复杂度是O(1),1次就能定位到,所以效率非常高。
总结:for循环便于访问顺序存储的记录,而foreach和迭代器便于访问链接存储。
以上就是“java迭代器和for循环优劣势是什么”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/4604431/blog/4475995