原文地址:http://blog.csdn.net/insistgogo/article/details/19619645java
一、建立一个ArrayListandroid
二、List经常使用的遍历方法有三种:ide
(1)下标循环oop
说明:性能
1)最通常的方法编码
2)idea快捷键:itar + Tab 或者 fori + Tabidea
(2)for each循环spa
说明:在不修改容器长度时,仅仅遍历容器时推荐使用。.net
1)优势:代码简洁美观:不存在索引,因此不用关心下标、初始值、是否越界等orm
2)缺点:删除容器中的元素容易出错。
3)idea快捷键:iter + Tab 或者 i + Tab
(3)迭代器循环
或者
说明:在删除容器中元素时,最好使用迭代器循环
1)优势:能对容器中的元素进行删除
2)idea快捷键:itco + Tab
三、三种遍历方法的效率比较
见文章:ArrayList和LinkedList的几种循环遍历方式及性能对比分析
这里该文章总结下:
(1)对于ArrayList而言:
1)从速度上看,foreach和迭代器循环速度差很少,可是都比下标遍历慢。
2)综合编码难度,在仅仅对集合进行遍历的时候,只使用for each
(2)对于LinkedList而言:
1)从速度上看,foreach和迭代器循环速度差很少,可是远比下标遍历快。
2)综合编码难度,在仅仅对集合进行遍历的时候,只使用for each
说明:
(1)对于LinkedList,GetAt方法须要一次遍历链表,其时间复杂度为O(n),所以使用下标遍历时,速度很慢,级别为n^2。
(2)对于ArrayList,GetAt方法直接使用下标定位,其时间复杂度为O(1),所以使用下标遍历时,级别为n。
总结:不管对于ArrayList仍是LinkedList,
(1)仅对其遍历而不修改容器大小时,只使用foreach循环
(2)须要边遍历边修改容器大小时(插入删除元素),只使用迭代器循环