future2012lg

博客园 首页 新随笔 联系 订阅 管理

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class ArrayTest
{
 public static void main(String[] args)
 {


  List<Integer> lstint = new ArrayList<Integer>();
  lstint.add(1);
  lstint.add(2);
  lstint.add(3);

 

  // Iterator遍历一
  Iterator<Integer> iterator = lstint.iterator();
  while (iterator.hasNext())
  {
   int i = (Integer) iterator.next();
   System.out.println(i);
  }

 

  // Iterator遍历二
  for (Iterator<Integer> it = lstint.iterator(); it.hasNext();)
  {
   int i = (Integer) it.next();
   System.out.println(i);
  }

 

  // for循环
  for (int i = 0; i < lstint.size(); i++)
  {
   System.out.println(lstint.get(i));
  }

 

  // for循环加强版
  for (Integer i : lstint)
  {
   System.out.println(i);
  }


 }


}


 摘自  IT胖子的专栏

 

对List的遍历有三种方式   
    
   List<A>    list    =    new    ArrayList<A>();   
   list.add(new    A());   
   list.add(new    A());   
   ...   
    
   第一种:   
   for(Iterator<A>    it    =    list.iterator();    it.hasNext();    )    {   
       ....   
   }   
   这种方式在循环

执行过程中会进行数据锁定,    性能稍差,    同时,如果你想在循环过程中去掉某个元素,只能调用it.remove方法,    不能使用list.remove方法,    否则一定出并发访问的错误.   
    
   第二种:   
   for(A    a    :    list)    {   
       .....   
   }   
   内部调用第一种,    换汤不换药,    这种循环方式还有其他限制,    不建议使用它   
    
   第三种:   
   for(int    i=0;    i<list.size();    i++)    {   
       A    a    =    list.get(i);   
       ...   
   }   
   内部不锁定,    效率最高,    但是当写多线程时要考虑并发操作的问题
posted on 2012-11-14 10:29  future2012lg  阅读(400)  评论(0编辑  收藏  举报