A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

© 18895700133 中级黑马   /  2016-5-10 22:35  /  501 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

java中的set接口有如下的特点:
  • 不允许出现重复元素;
    1. package cn.set;

    2. import java.util.HashSet;
    3. import java.util.Set;

    4. class Student{
    5.     int id;
    6.     public Student(int id) {
    7.         this.id = id;
    8.     }
    9.     @Override
    10.     public String toString() {
    11.         return this.id+"";
    12.     }
    13.     @Override
    14.     public int hashCode() {
    15.         return this.id;
    16.     }
    17.     @Override
    18.     public boolean equals(Object obj) {
    19.         if (obj instanceof Student){
    20.             Student  stu = (Student) obj;
    21.             if (stu.id == this.id)
    22.                 return true;
    23.         }
    24.         return false;
    25.     }
    26. }
    27. public class HashSetTest {
    28.     public static void main(String[] args) {
    29.         Set<Student> set = new HashSet<Student>();
    30.         Student s1 = new Student(1);
    31.         Student s2 = new Student(1);
    32.         Student s3 = new Student(2);
    33.         set.add(s1);
    34.         set.add(s2);
    35.         set.add(s3);
    36.         for (Student s : set) {
    37.             System.out.println(s);
    38.         }
    39.     }
    40. }
    复制代码

  • 集合中的元素位置无顺序;
  • 有且只有一个值为null的元素。
因为java中的set接口模仿了数学上的set抽象,所以,对应的数学上set的特性为:
  • 互异性:一个集合中,任何两个元素都认为是不相同的,即每个元素只能出现一次。
  • 无序性:一个集合中,每个元素的地位都是相同的,元素之间是无序的。集合上可以定义序关系,定义了序关系后,元素之间就可以按照序关系排序。但就集合本身的特性而言,元素之间没有必然的序。
  • 空集的性质:空集是一切集合的子集

      Set不保存重复的元素。Set中最常被使用的是测试归属性,你可以很容易的询问某个对象是否在某个Set中。Set具有与Collection完全一样的接口,因此没有任何额外的功能。实际上Set就是Collection,只是行为不同。
  实现了Set接口的主要有HashSet、TreeSet、LinkedHashSet这几个共同点就是每个相同的项只保存一份。他们也有不同点,区别如下:
  1.HashSet:
  HashSet使用的是相当复杂的方式来存储元素的,使用HashSet能够最快的获取集合中的元素,效率非常高(以空间换时间)。会根据hashcode和equals来庞端是否是同一个对象,如果hashcode一样,并且equals返回true,则是同一个对象,不能重复存放。


2.TreeSet
  TreeSet也不能存放重复对象,但是TreeSet会自动排序,如果存放的对象不能排序则会报错,所以存放的对象必须指定排序规则。排序规则包括自然排序和客户排序。
  ①自然排序:TreeSet要添加哪个对象就在哪个对象类上面实现java.lang.Comparable接口,并且重写comparaTo()方法,返回0则表示是同一个对象,否则为不同对象。
  ②客户排序:建立一个第三方类并实现java.util.Comparator接口。并重写方法。定义集合形式为TreeSet ts = new TreeSet(new 第三方类());
下面一个例子用TreeSet存放自然排序的对象:

  1. package cn.set;

  2. import java.util.Set;
  3. import java.util.TreeSet;

  4. class Student1 implements Comparable<Student1>{
  5.     int id;
  6.     public Student1(int id) {
  7.         this.id = id;
  8.     }
  9.     @Override
  10.     public String toString() {
  11.         return this.id+"";
  12.     }
  13.     @Override
  14.     public int hashCode() {
  15.         return this.id;
  16.     }
  17.     @Override
  18.     public boolean equals(Object obj) {
  19.         if (obj instanceof Student1){
  20.             Student1  stu = (Student1) obj;
  21.             if (stu.id == this.id)
  22.                 return true;
  23.         }
  24.         return false;
  25.     }
  26.     public int compareTo(Student1 o) {
  27.         return (this.id-o.id);
  28.     }
  29. }

  30. public class TreeSetTest {
  31.     public static void main(String[] args) {
  32.         Set<Student1> set = new TreeSet<Student1>();
  33.         Student1 s1 = new Student1(5);
  34.         Student1 s2 = new Student1(1);
  35.         Student1 s3 = new Student1(2);
  36.         Student1 s4 = new Student1(4);
  37.         Student1 s5 = new Student1(3);
  38.         set.add(s1);
  39.         set.add(s2);
  40.         set.add(s3);
  41.         set.add(s4);
  42.         set.add(s5);
  43.         for (Student1 s : set) {
  44.             System.out.println(s);
  45.         }
  46.     }

  47. }
复制代码
输出结果为:
1
2
3
4
5



0 个回复

您需要登录后才可以回帖 登录 | 加入黑马