Iterator稱之爲迭代器,是去遍歷Collection、Map集合中的元素對象。java
boolean hasNext()
:判斷是否還有下一個遍歷元素,若還有未被遍歷的元素,返回true;不然,返回false。Object next()
:返回集合裏的下一個元素;void remove()
:刪除集合裏上一次next方法返回的元素;void forEachRemaining(Consumer<? super E> action)
:Java 8 新增方法,可以使用Lambda表達式遍歷集合元素。內部經過hasNext()
方法進行遍歷,源碼以下:default void forEachRemaining(Consumer<? super E> action) { Objects.requireNonNull(action); while (hasNext()) action.accept(next()); }
public class DemoApplication { public static void main(String[] args) { Collection collection = new ArrayList(); // 添加元素 collection.add("add()方法"); collection.add("1"); collection.add("2.7"); collection.add("value1"); collection.add("value2"); //遍歷集合 Iterator iterator = collection.iterator(); while (iterator.hasNext()) { //next()方法 String colStr = (String)iterator.next(); System.out.println(colStr); //remove()方法 if ("value2".equals(colStr)) { iterator.remove(); } } System.out.println(collection); } }
運行結果:多線程
add()方法 1 2.7 value1 value2 [add()方法, 1, 2.7, value1]
當使用Iterator遍歷Collection集合時,集合內的元素不能被改變,只能經過Iterator的remove()
方法刪除上一次next()
方法返回的集合元素才能夠;不然會引發java.util.ConcurrentModificationException
異常。ui
在上述示例中咱們將iterator.remove();
換成collection.remove(colStr);
線程
public class DemoApplication { public static void main(String[] args) { Collection collection = new ArrayList(); // 添加元素 collection.add("add()方法"); collection.add("1"); collection.add("2.7"); collection.add("value1"); collection.add("value2"); //遍歷集合 Iterator iterator = collection.iterator(); while (iterator.hasNext()) { //next()方法 String colStr = (String)iterator.next(); System.out.println(colStr); //remove()方法 if ("value2".equals(colStr)) { //改變了集合,拋出異常之處 collection.remove(colStr); } } System.out.println(collection); } }
運行結果:code
add()方法 1 2.7 value1 value2 Exception in thread "main" java.util.ConcurrentModificationException at java.util.ArrayList$Itr.checkForComodification(ArrayList.java:909) at java.util.ArrayList$Itr.next(ArrayList.java:859) at com.example.andya.demo.DemoApplication.main(DemoApplication.java:30) Process finished with exit code 1
上述異常示例中,咱們能夠看到在Iterator遍歷Collection集合的過程當中,經過刪除集合元素修改了集合,程序運行時引起異常,而Iterator迭代器採用了快速失敗機制(fail-fast)
,一旦在遍歷過程當中發現集合已被修改,程序當即會拋出ConcurrentModificationException
異常,這能夠避免多線程中共享資源問題。對象
public class DemoApplication { public static void main(String[] args) { Collection collection = new ArrayList(); // 添加元素 collection.add("我"); collection.add("愛"); collection.add("中"); collection.add("國"); //遍歷集合 Iterator iterator = collection.iterator(); //使用Lambda表達式遍歷,目標類型是Consumer iterator.forEachRemaining(obj -> System.out.println(obj)); } }
運行結果接口
我 愛 中 國
固然,除了使用Iterator接口去遍歷,咱們還能夠經過foreach去遍歷集合,系統依次將集合元素的值賦給迭代遍歷。資源
**public class DemoApplication { public static void main(String[] args) { Collection collection = new ArrayList(); // 添加元素 collection.add("中"); collection.add("國"); collection.add("加"); collection.add("油"); //foreach遍歷,系統依次將元素值賦給遍歷object for (Object object : collection) { String str = (String) object; System.out.println(str); } } }
運行結果rem
中 國 加 油