增强型for和Iterator学习
1,增強for和對于非集合類(沒有實現 Iterable接口)的數組遍歷效果一樣
2,對于集合類,就是隱式調用迭代器 iterator的遍歷,各有各個場合
3,對于arraylist來所,由于數據結構是數據,可以獲得get的索引,反而用普通循環速度更快。linkedlist這種基于鏈表的數據結構,就用增強for速度比較快
List<String> list = new ArrayList<String>();for (int i = 0; i < 500000; i++) {list.add("xiaotang");}long start = System.currentTimeMillis();int size = list.size();String str = null;for (int i = 0; i < size; i++) {str = list.get(i);}System.out.println("for + get(i)方法: "+ (System.currentTimeMillis() - start));long start2 = System.currentTimeMillis();for (String str1 : list) {}System.out.println("Iterator(foreach)方法:"+ (System.currentTimeMillis() - start2)); View Code Iterator<Integer> itr = lst.iterator(); while (itr.hasNext()) if (itr.next() % 2 == 0) itr.remove();add/get/remove
4,增強for獲得實例,不能再循環中刪除,否則有異常,原理:foreach引用了iterator,調用hasnext和next方法,在外面remove會改變iterator的expectModeCount和list的modcount不同步),
iterator就有remove方法直接刪除(expectCount會自動同步),要想添加就要用原始的for,或者迭代器的刪了再加,保存平衡,foreach盡量只讀
參考:https://my.oschina.net/itblog/blog/422649
以下例子證明第一點 ① public static void removeEvensVer2(List<Integer> lst) { for (Integer x : lst) if (x % 2 == 0) lst.remove(x); System.out.println(lst); } ② public static void removeEvensVer3(List<Integer> lst) { Iterator<Integer> itr = lst.iterator(); while (itr.hasNext()) if (itr.next() % 2 == 0) itr.remove(); System.out.println(lst); } View Code5,map有4種方法,1,map.entrySet(),2,map.keySet()和map.values(),3,Iterator,4,通過keySet來便利
總結:鍵值都有用1,僅僅鍵或者值用2,刪除用iterator
參考,https://www.cnblogs.com/lchzls/p/6714689.html
真正的:https://blog.csdn.net/tjcyjd/article/details/11111401
?
轉載于:https://www.cnblogs.com/vhyc/p/9363652.html
總結
以上是生活随笔為你收集整理的增强型for和Iterator学习的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: react的一些思考
- 下一篇: BTrace是一个非常不错的java诊断