一、包含與刪除兩種方法解析 1.boolean contains(Object o);判斷集合中是否包含某個元素。 package com.bjpowernode.java_learning; import java.util.*; public class D85_1_ContainsMeth ...
一、包含與刪除兩種方法解析
1.boolean contains(Object o);判斷集合中是否包含某個元素。
package com.bjpowernode.java_learning; import java.util.*; public class D85_1_ContainsMethod { public static void main(String[] args) { //創建集合 Collection c = new ArrayList(); //創建兩個Integer類型的對象 Integer i1 = new Integer(10); //添加元素 c.add(i1); //判斷集合中是否包含11 System.out.println(c.contains(i1)); ///創建Integer類型的對象 Integer i2 = new Integer(10); System.out.println(c.contains(i2)); //這裡包含了i2說明瞭,contains底層調用了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; } //總結創建一個類,要重寫equals方法,才能對類中的數據進行對比,否則繼承原來的equals只能是對比對象的地址 }
2.boolean remove(Object o);刪除集合中某個元素。
總結:從這兩次輸出的結果就可以看出來,remove方法與contains方法在用法上是一致的
他們的底層全部都調用了equals方法來進行比較,因為在使用這個方法的時候,必須保證我們的原始類中equals方法已經被重寫,否則就會得到意想不到的結果。
package com.bjpowernode.java_learning; import java.util.*; public class D85_2_RemoveMethod { public static void main(String[] args) { //創建集合對象 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()); } }
3.深入remove方法
(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);//這裡複習了自動裝箱,int類型直接轉化為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);//這裡複習了自動裝箱,int類型直接轉化為Integer類型 c2.add(2); c2.add(3); Iterator it2 = c2.iterator(); while(it2.hasNext()) { Object element = it2.next(); c2.remove(element); } } }
解釋:
(1)如果要是刪除集合里的許多元素(一兩個無所謂,直接用集合的remove方法了),這時候推薦使用代碼中的第一種方法,迭代器的remove方法進行刪除;
(2)之所以不推薦第二種,用集合自身所帶的remove方法進行刪除,是因為會報截圖中的錯誤。產生這種錯誤是因為,當你初始化完一個迭代器之後,用迭代里的元素去刪除集合里的元素時,刪除第一個的時候還沒有報錯,但是刪除第二的時候,迭代器初始化後的內容,與此時的集合內容不一樣了(也就是集合少了一個元素,而迭代器還是完好的)產生了衝突,所以報錯,推薦使用第一種方法。
三、源碼:
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
2.CSDN:https://blog.csdn.net/weixin_44630050
3.博客園:https://www.cnblogs.com/ruigege0000/
4.歡迎關註微信公眾號:傅里葉變換,個人公眾號,僅用於學習交流,後臺回覆”禮包“,獲取大數據學習資料