您的位置:首页 > 其它

list 去除重复元素

2017-07-11 18:38 295 查看
对象重复是指对象里面的变量的值都相等,并不定是地址。list集合存储的类型是基础类型还比较好办,直接把list集合转换成set集合就会自动去除。
   当set集合存储的是对象类型时,需要在对象的实体类里面重写public boolean equals(Object obj) {} 和 public int hashCode() {} 两个方法。
  实体类

[html] view
plain copy

public class Student {  

  

public String id;  

public String name;  

public Student() {  

}  

public Student(String id,String name) {  

this.id = id;  

this.name = name;  

}  

public String getId() {  

return id;  

}  

public void setId(String id) {  

this.id = id;  

}  

public String getName() {  

return name;  

}  

public void setName(String name) {  

this.name = name;  

}  

@Override  

public boolean equals(Object obj) {  

Student s=(Student)obj;   

return id.equals(s.id) && name.equals(s.name);   

}  

@Override  

public int hashCode() {  

String in = id + name;  

return in.hashCode();  

}  

}  

测试

[html] view
plain copy

import java.util.ArrayList;  

import java.util.HashSet;  

import java.util.List;  

import java.util.Set;  

  

public class QuSame {  

      

    public static void main(String[] args) {  

        List<Student> stu = new ArrayList<Student>();  

        stu.add(new Student("1","yi"));  

        stu.add(new Student("3","san"));  

        stu.add(new Student("3","san"));  

        stu.add(new Student("2","er"));  

        stu.add(new Student("2","er"));  

        //set集合保存的是引用不同地址的对象  

        Set<Student> ts = new HashSet<Student>();  

        ts.addAll(stu);  

          

        for (Student student : ts) {  

            System.out.println(student.getId()+"-"+student.getName());  

        }  

    }  

}  

普通对象


方法1:使用HashSet删除ArrayList中重复的元素

在该方法中,我们使用HashSet来删除重复的元素。如你所知,HashSet不允许有重复的元素。我们使用HashSet的这个属性来删除已建 成的ArrayList中的重复元素。但是,这种方法有一个缺点。那就是,它会删除ArrayList中元素的插入顺序。这意味着,删除重复的元素后,元 素的插入顺序就不对了。先来看下面这个例子

[java] view
plain copy

import java.util.ArrayList;  

import java.util.HashSet;  

  

public class MainClass  

{  

    public static void main(String[] args)  

    {  

        //Constructing An ArrayList  

  

        ArrayList<String> listWithDuplicateElements = new ArrayList<String>();  

  

        listWithDuplicateElements.add("JAVA");  

  

        listWithDuplicateElements.add("J2EE");  

  

        listWithDuplicateElements.add("JSP");  

  

        listWithDuplicateElements.add("SERVLETS");  

  

        listWithDuplicateElements.add("JAVA");  

  

        listWithDuplicateElements.add("STRUTS");  

  

        listWithDuplicateElements.add("JSP");  

  

        //Printing listWithDuplicateElements  

  

        System.out.print("ArrayList With Duplicate Elements :");  

  

        System.out.println(listWithDuplicateElements);  

  

        //Constructing HashSet using listWithDuplicateElements  

  

        HashSet<String> set = new HashSet<String>(listWithDuplicateElements);  

  

        //Constructing listWithoutDuplicateElements using set  

  

        ArrayList<String> listWithoutDuplicateElements = new ArrayList<String>(set);  

  

        //Printing listWithoutDuplicateElements  

  

        System.out.print("ArrayList After Removing Duplicate Elements :");  

  

        System.out.println(listWithoutDuplicateElements);  

    }  

}  

输出:
ArrayList With Duplicate Elements :[JAVA, J2EE, JSP, SERVLETS, JAVA, STRUTS, JSP]

ArrayList After Removing Duplicate Elements :[JAVA, SERVLETS, JSP, J2EE, STRUTS]
注意输出结果。你会发现,在删除重复元素之后,元素重新洗牌。不再按照插入顺序排列。如果你想在删除重复的元素之后依然保持元素的插入顺序,那么不 建议使用此方法。还有另一种方法,可以保证在删除重复的元素之后也不改变元素的插入顺序。那就是使用LinkedHashSet。


方法2:使用LinkedHashSet删除ArrayList中重复的元素

在该方法中,我们使用LinkedHashSet删除ArrayList中重复的元素。正如你知道的,LinkedHashSet不允许重复元素, 同时保持元素的插入顺序。LinkedHashSet的这两个属性可以确保在删除ArrayList中的重复元素之后,依然保持元素的插入顺序。参见下面 的例子。

[java] view
plain copy

import java.util.ArrayList;  

import java.util.LinkedHashSet;  

  

public class MainClass  

{  

    public static void main(String[] args)  

    {  

        //Constructing An ArrayList  

  

        ArrayList<String> listWithDuplicateElements = new ArrayList<String>();  

  

        listWithDuplicateElements.add("JAVA");  

  

        listWithDuplicateElements.add("J2EE");  

  

        listWithDuplicateElements.add("JSP");  

  

        listWithDuplicateElements.add("SERVLETS");  

  

        listWithDuplicateElements.add("JAVA");  

  

        listWithDuplicateElements.add("STRUTS");  

  

        listWithDuplicateElements.add("JSP");  

  

        //Printing listWithDuplicateElements  

  

        System.out.print("ArrayList With Duplicate Elements :");  

  

        System.out.println(listWithDuplicateElements);  

  

        //Constructing LinkedHashSet using listWithDuplicateElements  

  

        LinkedHashSet<String> set = new LinkedHashSet<String>(listWithDuplicateElements);  

  

        //Constructing listWithoutDuplicateElements using set  

  

        ArrayList<String> listWithoutDuplicateElements = new ArrayList<String>(set);  

  

        //Printing listWithoutDuplicateElements  

  

        System.out.print("ArrayList After Removing Duplicate Elements :");  

  

        System.out.println(listWithoutDuplicateElements);  

    }  

}  

输出:
ArrayList With Duplicate Elements :[JAVA, J2EE, JSP, SERVLETS, JAVA, STRUTS, JSP]

ArrayList After Removing Duplicate Elements :[JAVA, J2EE, JSP, SERVLETS, STRUTS]
注意输出。你可以发现在删除ArrayList中的重复元素后,依然保持了元素的插入顺序。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: