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