Java中List集合的遍历实例详解
一、对List的遍历有三种方式
Listlist=newArrayList (); list.add("testone"); list.add(“testtwo”); ...
第一种:
for(Iteratorit=list.iterator();it.hasNext();){ .... }
这种方式在循环执行过程中会进行数据锁定, 性能稍差, 同时,如果你想在寻欢过程中去掉某个元素,只能调用it.remove方法, 不能使用list.remove方法, 否则一定出现并发访问的错误.
第二种:
for(Stringdata:list){ ..... }
内部调用第一种, 换汤不换药, 因此比Iterator慢,这种循环方式还有其他限制,不建议使用它。
第三种:
for(inti=0;i内部不锁定, 效率最高, 但是当写多线程时要考虑并发操作的问题。
二、测试实例
packagecom.inspur.Test; importjava.util.ArrayList; importjava.util.HashMap; importjava.util.Iterator; importjava.util.List; importjava.util.Map; importjava.util.Map.Entry; /** *@authorWHD *2015-3-5 */ @SuppressWarnings("unused") publicclassMapTest{ privatestaticListlist=newArrayList (); publicstaticvoidmain(String[]args){ MapTest mapTest=new MapTest(); mapTest.initList(list); mapTest.foreach(list); mapTest.forlist(list); mapTest.iteratorList(list); } //list集合中添加10万条数据 publicListinitList(List list){ inti=0; intnum=6000000; for(i=0;i list){ longstart=System.currentTimeMillis(); for(Stringdata:list){ Stringvalue=data; } longend=System.currentTimeMillis(); longcount=end-start; System.out.println("foreach循环时间"+count); } //list集合遍历 for publicvoidforlist(List list){ longstart=System.currentTimeMillis(); inti=0; for(i=0;i list){ longstart=System.currentTimeMillis(); for(Iterator it=list.iterator();it.hasNext();){ Stringvalue=it.next(); } longend=System.currentTimeMillis(); longcount=end-start; System.out.println("iterator遍历时间"+count); } } 三、测试结果:
(1)、第一次
foreach 遍历时间:55
forlist.size()遍历时间:47
iterator遍历时间:51(2)、第二次
foreach 遍历时间:54
forlist.size()遍历时间:44
iterator遍历时间:50(3)、第三次
foreach 遍历时间:48
forlist.size()遍历时间:43
iterator遍历时间:44从测试的结果我们可以明显的看到效率了!
以上所述是小编给大家介绍的Java中List集合遍历详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!