標籤:
原文網址:http://blog.csdn.net/player26/article/details/3955906
- import java.util.ArrayList;
- import java.util.Iterator;
- import java.util.List;
- public class ListTest {
- public static void main(String[] args) {
- List<Integer> list = new ArrayList<Integer>();
- list.add(1);
- list.add(2);
- list.add(3);
- for (Iterator i = list.iterator(); i.hasNext();)
- System.out.println(i.next()); // line 1
- }
- }
-
- public class ListTest2 {
- public static void main(String[] args){
- List list = new ArrayList();
- list.add(new Integer(100));
- list.add(new Float(150.60));
- list.add(new String("abc"));
- for(Iterator i = list.iterator(); i.hasNext();)
- System.out.println(i.next());
-
- // List<Integer> list = new ArrayList<Integer>();
- // list.add(1);
- // list.add(2);
- // list.add(3);
- // for(Integer i : list){
- // System.out.println(i); // OK
- // }
- }
- }
-
- //雖然List的Generic是Integer,但.next()返回的類型是Object
- public class ListTest3 {
- public static void main(String[] args) {
- // List<Integer> list = new ArrayList<Integer>();
- // list.add(1);
- // list.add(2);
- // list.add(3);
- // for(Iterator i = list.iterator(); i.hasNext();){
- // Integer integerRef = (Integer) i.next(); //line 1
- // //Compile Error
- // System.out.println(integerRef); // line 2
- // }
- List<Integer> list = new ArrayList<Integer>();
- list.add(1);
- list.add(2);
- list.add(3);
- for (Iterator<Integer> i = list.iterator(); i.hasNext();) {
- Integer integerRef = i.next(); // line 1
- // OK
- System.out.println(integerRef); // line 2
- }
- }
- }
對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);
...
}
內部不鎖定, 效率最高, 但是當寫多線程時要考慮並行作業的問題!
【轉】Java中 List的遍曆