您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“java中怎么解決list集合做刪除操作時(shí)的坑”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“java中怎么解決list集合做刪除操作時(shí)的坑”吧!
一個(gè)ArrayList在做刪除操作時(shí),如果你使用如下方式,會(huì)有什么問題?
import java.util.ArrayList; import java.util.List; public class DeleteList { public static void main(String[] args) { List<Integer> list = new ArrayList<Integer>(); list.add(1); list.add(2); list.add(3); list.add(3); list.add(3); list.add(4); for(int i=0;i<list.size();i++){ if (list.get(i)==3) { list.remove(i); } } System.out.println(list); } }
結(jié)果:[1, 2, 3, 4]。
分析問題:為什么會(huì)是有一個(gè)3遺留了?因?yàn)樵谠L問到list[2]時(shí),滿足等于3,進(jìn)行刪除。此時(shí),3后面的元素會(huì)向左移動(dòng)一位,也就是第二個(gè)3進(jìn)入到i=2處,然后i=3,刪除第三個(gè)3,這樣就會(huì)漏掉第二個(gè)3.
1、訪問list從后往前,從i=size-1至i=0,可以避免上述問題;
2、使用iterator迭代器。
Iterator it = list.iterator(); while (it.hasNext()) { Integer p = (Integer) it.next(); if(p==3){ it.remove(); } } System.out.println(list);
結(jié)果:[1, 2, 4]
下面是迭代器的部分源碼:當(dāng)執(zhí)行remove方法時(shí),將當(dāng)前位置賦值給游標(biāo)cursor,再進(jìn)行next時(shí),還是獲取當(dāng)前位置的元素,也就是下一個(gè)位置移動(dòng)過來的元素。這樣就避免的遺漏元素。關(guān)鍵點(diǎn)是刪除時(shí),當(dāng)前位置是i,游標(biāo)的位置是i+1,修改游標(biāo)的位置為i。
public E next() { checkForComodification(); int i = cursor; if (i >= size) throw new NoSuchElementException(); Object[] elementData = ArrayList.this.elementData; if (i >= elementData.length) throw new ConcurrentModificationException(); cursor = i + 1; return (E) elementData[lastRet = i]; } public void remove() { if (lastRet < 0) throw new IllegalStateException(); checkForComodification(); try { ArrayList.this.remove(lastRet); cursor = lastRet; lastRet = -1; expectedModCount = modCount; } catch (IndexOutOfBoundsException ex) { throw new ConcurrentModificationException(); } }
備注:內(nèi)容中代碼具有關(guān)聯(lián)性。
添加方法是:.add(e)
獲取方法是:.get(index)
刪除方法是:.remove(index)
按照索引刪除;.remove(Object o)
按照元素內(nèi)容刪除;
List<String> person=new ArrayList<>(); person.add("jackie"); //索引為0 //.add(e) person.add("peter"); //索引為1 person.add("annie"); //索引為2 person.add("martin"); //索引為3 person.add("marry"); //索引為4 person.remove(3); //.remove(index) person.remove("marry"); //.remove(Object o) String per=""; per=person.get(1); System.out.println(per); ////.get(index) for (int i = 0; i < person.size(); i++) { System.out.println(person.get(i)); //.get(index) }
方法:.contains(Object o); 返回true或者false
List<String> fruits=new ArrayList<>(); fruits.add("蘋果"); fruits.add("香蕉"); fruits.add("桃子"); //for循環(huán)遍歷list for (int i = 0; i < fruits.size(); i++) { System.out.println(fruits.get(i)); } String appleString="蘋果"; //true or false System.out.println("fruits中是否包含蘋果:"+fruits.contains(appleString)); if (fruits.contains(appleString)) { System.out.println("我喜歡吃蘋果"); }else { System.out.println("我不開心"); }
注意 .set(index, element); 和 .add(index, element); 的不同;
String a="白龍馬", b="沙和尚", c="八戒", d="唐僧", e="悟空"; List<String> people=new ArrayList<>(); people.add(a); people.add(b); people.add(c); people.set(0, d); //.set(index, element); //將d唐僧放到list中索引為0的位置,替換a白龍馬 people.add(1, e); //.add(index, element); //將e悟空放到list中索引為1的位置,原來位置的b沙和尚后移一位 //增強(qiáng)for循環(huán)遍歷list for(String str:people){ System.out.println(str); }
注意:.indexOf(); 和 lastIndexOf()的不同;
List<String> names=new ArrayList<>(); names.add("劉備"); //索引為0 names.add("關(guān)羽"); //索引為1 names.add("張飛"); //索引為2 names.add("劉備"); //索引為3 names.add("張飛"); //索引為4 System.out.println(names.indexOf("劉備")); System.out.println(names.lastIndexOf("劉備")); System.out.println(names.indexOf("張飛")); System.out.println(names.lastIndexOf("張飛"));
if (names.indexOf("劉備")==0) { System.out.println("劉備在這里"); }else if (names.lastIndexOf("劉備")==3) { System.out.println("劉備在那里"); }else { System.out.println("劉備到底在哪里?"); }
方法:
.subList(fromIndex, toIndex)
.size()
該方法得到list中的元素?cái)?shù)的和
List<String> phone=new ArrayList<>(); phone.add("三星"); //索引為0 phone.add("蘋果"); //索引為1 phone.add("錘子"); //索引為2 phone.add("華為"); //索引為3 phone.add("小米"); //索引為4 //原list進(jìn)行遍歷 for(String pho:phone){ System.out.println(pho); } //生成新list phone=phone.subList(1, 4); //.subList(fromIndex, toIndex) //利用索引1-4的對象重新生成一個(gè)list,但是不包含索引為4的元素,4-1=3 for (int i = 0; i < phone.size(); i++) { // phone.size() 該方法得到list中的元素?cái)?shù)的和 System.out.println("新的list包含的元素是"+phone.get(i)); }
兩個(gè)相等對象的equals方法一定為true, 但兩個(gè)hashcode相等的對象不一定是相等的對象
//1.<br>if (person.equals(fruits)) { System.out.println("兩個(gè)list中的所有元素相同"); }else { System.out.println("兩個(gè)list中的所有元素不一樣"); } //2. if (person.hashCode()==fruits.hashCode()) { System.out.println("我們相同"); }else { System.out.println("我們不一樣"); }
//空則返回true,非空則返回false
if (person.isEmpty()) { System.out.println("空的"); }else { System.out.println("不是空的"); }
System.out.println("返回Iterator集合對象:"+person.iterator());
String liString=""; liString=person.toString(); System.out.println("將集合轉(zhuǎn)換為字符串:"+liString);
System.out.println("將集合轉(zhuǎn)換為數(shù)組:"+person.toArray());
//1.默認(rèn)類型 List<Object> listsStrings=new ArrayList<>(); for (int i = 0; i < person.size(); i++) { listsStrings.add(person.get(i)); } //2.指定類型 List<StringBuffer> lst=new ArrayList<>(); for(String string:person){ lst.add(StringBuffer(string)); }
List<String> lst1=new ArrayList<>(); lst1.add("aa"); lst1.add("dd"); lst1.add("ss"); lst1.add("aa"); lst1.add("ss"); //方法 1. for (int i = 0; i <lst1.size()-1; i++) { for (int j = lst1.size()-1; j >i; j--) { if (lst1.get(j).equals(lst1.get(i))) { lst1.remove(j); } } } System.out.println(lst1); //方法 2. List<String> lst2=new ArrayList<>(); for (String s:lst1) { if (Collections.frequency(lst2, s)<1) { lst2.add(s); } } System.out.println(lst2);
附完整代碼:
package MyTest01; import java.util.ArrayList; import java.util.List; public class ListTest01 { public static void main(String[] args) { //list中添加,獲取,刪除元素 List<String> person=new ArrayList<>(); person.add("jackie"); //索引為0 //.add(e) person.add("peter"); //索引為1 person.add("annie"); //索引為2 person.add("martin"); //索引為3 person.add("marry"); //索引為4 person.remove(3); //.remove(index) person.remove("marry"); //.remove(Object o) String per=""; per=person.get(1); System.out.println(per); ////.get(index) for (int i = 0; i < person.size(); i++) { System.out.println(person.get(i)); //.get(index) } //list總是否包含某個(gè)元素 List<String> fruits=new ArrayList<>(); fruits.add("蘋果"); fruits.add("香蕉"); fruits.add("桃子"); //for循環(huán)遍歷list for (int i = 0; i < fruits.size(); i++) { System.out.println(fruits.get(i)); } String appleString="蘋果"; //true or false System.out.println("fruits中是否包含蘋果:"+fruits.contains(appleString)); if (fruits.contains(appleString)) { System.out.println("我喜歡吃蘋果"); }else { System.out.println("我不開心"); } //list中根據(jù)索引將元素?cái)?shù)值改變(替換) String a="白龍馬", b="沙和尚", c="八戒", d="唐僧", e="悟空"; List<String> people=new ArrayList<>(); people.add(a); people.add(b); people.add(c); people.set(0, d); //.set(index, element) //將d唐僧放到list中索引為0的位置,替換a白龍馬 people.add(1, e); //.add(index, element); //將e悟空放到list中索引為1的位置,原來位置的b沙和尚后移一位 //增強(qiáng)for循環(huán)遍歷list for(String str:people){ System.out.println(str); } //list中查看(判斷)元素的索引 List<String> names=new ArrayList<>(); names.add("劉備"); //索引為0 names.add("關(guān)羽"); //索引為1 names.add("張飛"); //索引為2 names.add("劉備"); //索引為3 names.add("張飛"); //索引為4 System.out.println(names.indexOf("劉備")); System.out.println(names.lastIndexOf("劉備")); System.out.println(names.indexOf("張飛")); System.out.println(names.lastIndexOf("張飛")); //根據(jù)元素索引位置進(jìn)行的判斷 if (names.indexOf("劉備")==0) { System.out.println("劉備在這里"); }else if (names.lastIndexOf("劉備")==3) { System.out.println("劉備在那里"); }else { System.out.println("劉備到底在哪里?"); } //利用list中索引位置重新生成一個(gè)新的list(截取集合) List<String> phone=new ArrayList<>(); phone.add("三星"); //索引為0 phone.add("蘋果"); //索引為1 phone.add("錘子"); //索引為2 phone.add("華為"); //索引為3 phone.add("小米"); //索引為4 //原list進(jìn)行遍歷 for(String pho:phone){ System.out.println(pho); } //生成新list phone=phone.subList(1, 4); //.subList(fromIndex, toIndex) //利用索引1-4的對象重新生成一個(gè)list,但是不包含索引為4的元素,4-1=3 for (int i = 0; i < phone.size(); i++) { // phone.size() 該方法得到list中的元素?cái)?shù)的和 System.out.println("新的list包含的元素是"+phone.get(i)); } //對比兩個(gè)list中的所有元素 //兩個(gè)相等對象的equals方法一定為true, 但兩個(gè)hashcode相等的對象不一定是相等的對象 if (person.equals(fruits)) { System.out.println("兩個(gè)list中的所有元素相同"); }else { System.out.println("兩個(gè)list中的所有元素不一樣"); } if (person.hashCode()==fruits.hashCode()) { System.out.println("我們相同"); }else { System.out.println("我們不一樣"); } //判斷l(xiāng)ist是否為空 //空則返回true,非空則返回false if (person.isEmpty()) { System.out.println("空的"); }else { System.out.println("不是空的"); } //返回Iterator集合對象 System.out.println("返回Iterator集合對象:"+person.iterator()); //將集合轉(zhuǎn)換為字符串 String liString=""; liString=person.toString(); System.out.println("將集合轉(zhuǎn)換為字符串:"+liString); //將集合轉(zhuǎn)換為數(shù)組,默認(rèn)類型 System.out.println("將集合轉(zhuǎn)換為數(shù)組:"+person.toArray()); ////將集合轉(zhuǎn)換為指定類型(友好的處理) //1.默認(rèn)類型 List<Object> listsStrings=new ArrayList<>(); for (int i = 0; i < person.size(); i++) { listsStrings.add(person.get(i)); } //2.指定類型 List<StringBuffer> lst=new ArrayList<>(); for(String string:person){ lst.add(StringBuffer(string)); } } private static StringBuffer StringBuffer(String string) { return null; } }
到此,相信大家對“java中怎么解決list集合做刪除操作時(shí)的坑”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。