JAVA集合Set使用

    xiaoxiao2021-04-14  32

    从现在开始练习JAVASE部分,每天的练习题记录下来,以便以后翻阅,也给自己一些鼓励

    Java集合Set简单使用

    /*  * Collection   * ----List  * ----ArrayList  * ----LinkedList  * ----Vector  * ----SET  * ----HashSet  * ----LinkedHashSet  * ----TreeSet  */

    TreeSet集合使用有两种排序方式:

    1. 自然排序,存入的对象需要实现Comparable接口,里面含有CompareTo(Object o)方法

    2.定制排序,在创建TreeSet对象时需要给构造器传入Comparator接口的实现类对象,里面含有Compare(Object o1, Object o2)方法

    另外建议需要存入Collection下面的类对象都重写equals方法和hashCode方法

    下面是使用定制排序,最后一段Person类含有自然排序需要实现的Comparable代码,也可以运行

    package test1; import java.util.Comparator; import java.util.HashSet; import java.util.LinkedHashSet; import java.util.Set; import java.util.TreeSet; /*  * Collection   * ----List  * ----ArrayList  * ----LinkedList  * ----Vector  * ----SET  * ----HashSet  * ----LinkedHashSet  * ----TreeSet  */ public class testSet { public static void main(String[] args) { Set linkArr = new TreeSet(new Com()); // linkArr.add("ABC");  linkArr.add(new Person("RayLu",31)); // linkArr.add(null); linkArr.add(new Person("Tome",31)); linkArr.add(new Person("RayLu",32)); linkArr.add(new Person("Jack",32)); for(Object o : linkArr){ System.out.println(o); } } } class Com implements Comparator{ @Override public int compare(Object o1, Object o2) { if(o1 instanceof Person && o2 instanceof Person){ Person p1 = (Person)o1; Person p2 = (Person)o2; if(p1.getAge() !=  p2.getAge()){ return p1.getAge() - p2.getAge(); }else  return p1.getName().compareTo(p2.getName()); } return 0; } } class Person{ private String name; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "Person [name=" + name + ", age=" + age + "]"; } public Person(String name, int age) { super(); this.name = name; this.age = age; } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + age; result = prime * result + ((name == null) ? 0 : name.hashCode()); return result; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; Person other = (Person) obj; if (age != other.age) return false; if (name == null) { if (other.name != null) return false; } else if (!name.equals(other.name)) return false; return true; } // @Override // public int compareTo(Object o) { // if(o instanceof Person){ // Person p = (Person)o; // if(this.age != p.age){ // return this.age - p.age; // }else  // return this.getName().compareTo(p.name); // } // return 0; // } }

    转载请注明原文地址: https://ju.6miu.com/read-669781.html

    最新回复(0)