有時候我們需要在一個ArrayList的for循環(huán)中動態(tài)刪除元素的需求, 廢話不多說看代碼
成都創(chuàng)新互聯(lián)服務(wù)項目包括城關(guān)網(wǎng)站建設(shè)、城關(guān)網(wǎng)站制作、城關(guān)網(wǎng)頁制作以及城關(guān)網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,城關(guān)網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到城關(guān)省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
Listlist = new ArrayList (); list.add(0); list.add(1); list.add(2); list.add(3); list.add(4); list.add(5); list.add(6); list.add(7); //正常循環(huán) for (int i = 0; i < list.size(); i++) { System.out.println("i的值:" + i + " 對應(yīng)的數(shù)字:" + list.get(i)); } System.out.println("沒有remove前l(fā)ist的項:"+list.size()); //邊循環(huán)邊刪除 for (int i = 0; i < list.size(); i++) { System.out.println("i的值:" + i + " 對應(yīng)的數(shù)字:" + list.get(i)); if(list.get(i) == 3) list.remove(list.get(i));//刪除list的第四項 } System.out.println("remove后list的項:"+list.size()); System.out.println("==========remove后的list=========="); for (int i = 0; i < list.size(); i++) { System.out.println("i的值:" + i + " 對應(yīng)的數(shù)字:" + list.get(i)); }
執(zhí)行代碼, 結(jié)果如下:
i的值:0 對應(yīng)的數(shù)字:0 i的值:1 對應(yīng)的數(shù)字:1 i的值:2 對應(yīng)的數(shù)字:2 i的值:3 對應(yīng)的數(shù)字:3 i的值:4 對應(yīng)的數(shù)字:4 i的值:5 對應(yīng)的數(shù)字:5 i的值:6 對應(yīng)的數(shù)字:6 i的值:7 對應(yīng)的數(shù)字:7 沒有remove前l(fā)ist的項:8 i的值:0 對應(yīng)的數(shù)字:0 i的值:1 對應(yīng)的數(shù)字:1 i的值:2 對應(yīng)的數(shù)字:2 i的值:3 對應(yīng)的數(shù)字:3 i的值:4 對應(yīng)的數(shù)字:5 i的值:5 對應(yīng)的數(shù)字:6 i的值:6 對應(yīng)的數(shù)字:7 remove后list的項:7 ==========remove后的list========== i的值:0 對應(yīng)的數(shù)字:0 i的值:1 對應(yīng)的數(shù)字:1 i的值:2 對應(yīng)的數(shù)字:2 i的值:3 對應(yīng)的數(shù)字:4 i的值:4 對應(yīng)的數(shù)字:5 i的值:5 對應(yīng)的數(shù)字:6 i的值:6 對應(yīng)的數(shù)字:7
可以看到?jīng)]有刪除前, 我們的list的項和循環(huán)對應(yīng)的數(shù)字都是正確的, 但是下面的循環(huán)在刪除第4個元素后,第4,5,6個項對應(yīng)的數(shù)字本應(yīng)該是4,5,6, 但是這里卻變成了5,6,7.
原因是,我們刪除第4項后,list的長度就變成7,而且,list會把第4項后面的值往前移一位, 也就是說,i=3時,list.get(i)=4,i=4時,list.get(i)=5,i=5時,list.get(i)=6,i=6時,list.get(i)=7.. 我們再說的形象一點, 就是本來有8層糕點,依次是0-7,豎起來,大的在上,小的在下,我們從下往上數(shù),數(shù)到第5個的時候,吃掉這一層糕點,這時,上面三層分別往下移了一層
所以, 值為4的項我們根本沒有循環(huán)到
那有什么方法可以實現(xiàn)remove呢, 有個笨方法,是新建一個tempList, 把要刪除的項全部add進去,最后用list.removeAll(tempList)實現(xiàn) . 但是這里我們有更好的方法, 就是倒序刪除
還是上面的例子, 我們看代碼:
Listlist = new ArrayList (); list.add(0); list.add(1); list.add(2); list.add(3); list.add(4); list.add(5); list.add(6); list.add(7); //正常循環(huán) for (int i = 0; i < list.size(); i++) { System.out.println("i的值:" + i + " 對應(yīng)的數(shù)字:" + list.get(i)); } System.out.println("沒有remove前l(fā)ist的項:"+list.size()); //邊循環(huán)邊刪除 for (int i = list.size() -1 ; i >= 0; i--) { System.out.println("i的值 " + i + " 對應(yīng)的數(shù)字 " + list.get(i)); if(list.get(i) == 3) list.remove(list.get(i)); } System.out.println("remove后list的項:"+list.size()); System.out.println("==========remove后的list=========="); for (int i = 0; i < list.size(); i++) { System.out.println("i的值 " + i + " 對應(yīng)的數(shù)字 " + list.get(i)); }
執(zhí)行代碼,結(jié)果如下:
i的值:0 對應(yīng)的數(shù)字:0 i的值:1 對應(yīng)的數(shù)字:1 i的值:2 對應(yīng)的數(shù)字:2 i的值:3 對應(yīng)的數(shù)字:3 i的值:4 對應(yīng)的數(shù)字:4 i的值:5 對應(yīng)的數(shù)字:5 i的值:6 對應(yīng)的數(shù)字:6 i的值:7 對應(yīng)的數(shù)字:7 沒有remove前l(fā)ist的項:8 i的值 7 對應(yīng)的數(shù)字 7 i的值 6 對應(yīng)的數(shù)字 6 i的值 5 對應(yīng)的數(shù)字 5 i的值 4 對應(yīng)的數(shù)字 4 i的值 3 對應(yīng)的數(shù)字 3 i的值 2 對應(yīng)的數(shù)字 2 i的值 1 對應(yīng)的數(shù)字 1 i的值 0 對應(yīng)的數(shù)字 0 remove后list的項:7 ==========remove后的list========== i的值 0 對應(yīng)的數(shù)字 0 i的值 1 對應(yīng)的數(shù)字 1 i的值 2 對應(yīng)的數(shù)字 2 i的值 3 對應(yīng)的數(shù)字 4 i的值 4 對應(yīng)的數(shù)字 5 i的值 5 對應(yīng)的數(shù)字 6 i的值 6 對應(yīng)的數(shù)字 7
我們可以看到變循環(huán)變刪除,并不影響后面的元素, remove后的list也和第一次的結(jié)果是一樣的 . 這是因為我們刪除list元素,list的長度是會變小, 但是變化的只是比當(dāng)前被刪除元素的項大的項, 而我們這里使用倒序循環(huán), 大的項, 我們已經(jīng)執(zhí)行過了, 所以不會影響.. 再用上面的比喻來說明,這次我們是從上往下數(shù),數(shù)到第4個的時候,吃掉這一層糕點,這時,上面三層分別往下移了一層 , 但是這不影響我們之前數(shù)過的蛋糕, 而且對下面的蛋糕也不影響, 這就是原理
總結(jié)
以上就是本文關(guān)于ArrayList在for循環(huán)中使用remove方法移除元素方法介紹的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以參閱:Java實現(xiàn)跳躍表(skiplist)的簡單實例 Java多線程ForkJoinPool實例詳解 等。感謝朋友們對創(chuàng)新互聯(lián)網(wǎng)站的支持。有什么問題或者想要了解的可以隨時給我們留言,小編會及時回復(fù)大家的。