增强型for和Iterator学习
1,增強(qiáng)for和對(duì)于非集合類(沒(méi)有實(shí)現(xiàn) Iterable接口)的數(shù)組遍歷效果一樣
2,對(duì)于集合類,就是隱式調(diào)用迭代器 iterator的遍歷,各有各個(gè)場(chǎng)合
3,對(duì)于arraylist來(lái)所,由于數(shù)據(jù)結(jié)構(gòu)是數(shù)據(jù),可以獲得get的索引,反而用普通循環(huán)速度更快。linkedlist這種基于鏈表的數(shù)據(jù)結(jié)構(gòu),就用增強(qiáng)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,增強(qiáng)for獲得實(shí)例,不能再循環(huán)中刪除,否則有異常,原理:foreach引用了iterator,調(diào)用hasnext和next方法,在外面remove會(huì)改變iterator的expectModeCount和list的modcount不同步),
iterator就有remove方法直接刪除(expectCount會(huì)自動(dòng)同步),要想添加就要用原始的for,或者迭代器的刪了再加,保存平衡,foreach盡量只讀
參考:https://my.oschina.net/itblog/blog/422649
以下例子證明第一點(diǎn) ① 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,通過(guò)keySet來(lái)便利
總結(jié):鍵值都有用1,僅僅鍵或者值用2,刪除用iterator
參考,https://www.cnblogs.com/lchzls/p/6714689.html
真正的:https://blog.csdn.net/tjcyjd/article/details/11111401
?
轉(zhuǎn)載于:https://www.cnblogs.com/vhyc/p/9363652.html
總結(jié)
以上是生活随笔為你收集整理的增强型for和Iterator学习的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: react的一些思考
- 下一篇: BTrace是一个非常不错的java诊断