Java集合框架迭代器Iterator實現原理解析
使用循環遍歷集合
普通for循環
for(int i=0;i<10;i++){}
增強for循環
for(String str:list){}
什么是迭代器Iterator
Iterator是Java中的一個接口,核心作用就是用來遍歷容器的元素,當容器實現了Iterator接口后,可以通過調用Iterator()方法獲取一個Iterator對象
為啥是調用容器里面的Iterator方法呢?
因為容器的實現有多種,不同的容器遍歷規則不一樣,比如:ArrayList、LinkedList、HashSet、TreeSet等,所以設計了Iterator接口,讓容器本身去實現這個接口,實現里面的方法,從而讓開發人員不用關心容器的遍歷機制,直接使用對應的方法即可
三個核心方法
boolean hashNext():用于判斷Iterator內是否有下個元素,如果有則返回true,沒有則false Object next():返回Iterator的下一個元素,同時指針也會向后移動一位 void remove():刪除指針的上一個元素(建議使用自己容器里的方法)public static void testSet() { Set<String> set = new HashSet<>(); set.add('jack'); set.add('tom'); set.add('marry'); set.add('tony'); set.add('jack'); Iterator<String> iterator = set.iterator(); while (iterator.hasNext()) { String str = iterator.next(); System.out.println(str); } } public static void testList() { List<String> list = new ArrayList<>(); list.add('jack'); list.add('tom'); list.add('mary'); list.add('tim'); list.add('tony'); list.add('eric'); list.add('jack'); Iterator<String> iterator = list.iterator(); while (iterator.hasNext()) { String str = iterator.next(); System.out.println(str); } }
迭代器和for循環對比
for循環適合順序訪問,或者通過下標進行訪問 迭代器適合鏈式結構 最終要看使用場景,性能會有輕微差別,但是可以忽略注意事項
迭代出的對象是引用的拷貝,如果修改迭代中的元素,那么就是修改容器對象的本身!!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
相關文章: