Java 集合的Contains和Remove方法
package com.bjpowernode.java_learning;import java.util.*;public class D85_1_ContainsMethod { public static void main(String[] args) { //創(chuàng)建集合 Collection c = new ArrayList(); //創(chuàng)建兩個(gè)Integer類型的對(duì)象 Integer i1 = new Integer(10); //添加元素 c.add(i1); //判斷集合中是否包含11 System.out.println(c.contains(i1)); ///創(chuàng)建Integer類型的對(duì)象 Integer i2 = new Integer(10); System.out.println(c.contains(i2)); //這里包含了i2說明了,contains底層調(diào)用了equals方法。如果equals返回了true,就是包含 Manager85 m1 = new Manager85(52,'jho'); c.add(m1); Manager85 m2 = new Manager85(52,'jho'); System.out.println(c.contains(m2)); }}class Manager85{ int no; String name; Manager85(int no,String name){ this.no = no; this.name = name; } public boolean equals(Object o){ if(this==o) return true; if(o instanceof Manager85) { Manager85 m = (Manager85)o; if(this.no==m.no && this.name.equals(m.name)){ return true; } } return false; } //總結(jié)創(chuàng)建一個(gè)類,要重寫equals方法,才能對(duì)類中的數(shù)據(jù)進(jìn)行對(duì)比,否則繼承原來的equals只能是對(duì)比對(duì)象的地址}
總結(jié):從這兩次輸出的結(jié)果就可以看出來,remove方法與contains方法在用法上是一致的
他們的底層全部都調(diào)用了equals方法來進(jìn)行比較,因?yàn)樵谑褂眠@個(gè)方法的時(shí)候,必須保證我們的原始類中equals方法已經(jīng)被重寫,否則就會(huì)得到意想不到的結(jié)果。
package com.bjpowernode.java_learning;import java.util.*;public class D85_2_RemoveMethod { public static void main(String[] args) { //創(chuàng)建集合對(duì)象 Collection c = new ArrayList(); Integer i1 = new Integer(10); //添加元素 c.add(i1); //刪除 Integer i2 = new Integer(10); c.remove(i2); System.out.println(c.size()); Manager85 m1 = new Manager85(10,'ji'); c.add(m1); Manager85 m2 = new Manager85(10,'ji'); c.remove(m2); System.out.println(c.size()); }}
(1)迭代器的remove方法;
(2)集合自身的remove方法
package com.bjpowernode.java_learning;import java.util.*;import java.lang.Iterable;public class D85_3_DeepIntoRemoveMethod { public static void main(String[] args) { Collection c = new ArrayList(); c.add(1);//這里復(fù)習(xí)了自動(dòng)裝箱,int類型直接轉(zhuǎn)化為Integer類型 c.add(2); c.add(3); //遍歷 Iterator it = c.iterator(); while(it.hasNext()) { Object element = it.next(); //刪除 it.remove();//通過迭代器的remove方法刪除 } System.out.println(c.size()); Collection c2 = new ArrayList(); c2.add(1);//這里復(fù)習(xí)了自動(dòng)裝箱,int類型直接轉(zhuǎn)化為Integer類型 c2.add(2); c2.add(3); Iterator it2 = c2.iterator(); while(it2.hasNext()) { Object element = it2.next(); c2.remove(element); } }}
解釋:
(1)如果要是刪除集合里的許多元素(一兩個(gè)無所謂,直接用集合的remove方法了),這時(shí)候推薦使用代碼中的第一種方法,迭代器的remove方法進(jìn)行刪除;
(2)之所以不推薦第二種,用集合自身所帶的remove方法進(jìn)行刪除,是因?yàn)?#8203;會(huì)報(bào)截圖中的錯(cuò)誤。產(chǎn)生這種錯(cuò)誤是因?yàn)椋?dāng)你初始化完一個(gè)迭代器之后,用迭代里的元素去刪除集合里的元素時(shí),刪除第一個(gè)的時(shí)候還沒有報(bào)錯(cuò),但是刪除第二的時(shí)候,迭代器初始化后的內(nèi)容,與此時(shí)的集合內(nèi)容不一樣了(也就是集合少了一個(gè)元素,而迭代器還是完好的)產(chǎn)生了沖突,所以報(bào)錯(cuò),推薦使用第一種方法。
三、源碼:D85_1_ContainsMethod.java
D85_2_RemoveMethod.java
D85_3_DeepIntoRemoveMethod.java
https://github.com/ruigege66/Java/blob/master/D85_1_ContainsMethod.java
https://github.com/ruigege66/Java/blob/master/D85_2_RemoveMethod.java
https://github.com/ruigege66/Java/blob/master/D85_3_DeepIntoRemoveMethod.java
以上就是Java 集合的Contains和Remove方法的詳細(xì)內(nèi)容,更多關(guān)于Java Contains和Remove的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. ASP實(shí)現(xiàn)加法驗(yàn)證碼2. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向3. 將properties文件的配置設(shè)置為整個(gè)Web應(yīng)用的全局變量實(shí)現(xiàn)方法4. asp(vbs)Rs.Open和Conn.Execute的詳解和區(qū)別及&H0001的說明5. CSS hack用法案例詳解6. ASP.NET MVC遍歷驗(yàn)證ModelState的錯(cuò)誤信息7. asp中response.write("中文")或者js中文亂碼問題8. PHP設(shè)計(jì)模式中工廠模式深入詳解9. jsp網(wǎng)頁實(shí)現(xiàn)貪吃蛇小游戲10. 用css截取字符的幾種方法詳解(css排版隱藏溢出文本)
