zoukankan      html  css  js  c++  java
  • Set接口

    原文链接:java笔记四:Set接口

    Set不保存重复的元素。Set中最常被使用的是测试归属性,你可以很容易的询问某个对象是否在某个Set中。Set具有与Collection完全一样的接口,因此没有任何额外的功能。实际上Set就是Collection,只是行为不同。

      实现了Set接口的主要有HashSet、TreeSet、LinkedHashSet这几个共同点就是每个相同的项只保存一份。他们也有不同点,区别如下:

      1.HashSet:

      HashSet使用的是相当复杂的方式来存储元素的,使用HashSet能够最快的获取集合中的元素,效率非常高(以空间换时间)。会根据hashcode和equals来庞端是否是同一个对象,如果hashcode一样,并且equals返回true,则是同一个对象,不能重复存放。

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

    正如上例所示,重写了hashCode()和equals()方法来区分同意对象后,就不能存放同以对象了。如果注释这两个方法,则所有Student对象视为不同对象,都可以存放。

      2.TreeSet

      TreeSet也不能存放重复对象,但是TreeSet会自动排序,如果存放的对象不能排序则会报错,所以存放的对象必须指定排序规则。排序规则包括自然排序和客户排序。

      ①自然排序:TreeSet要添加哪个对象就在哪个对象类上面实现java.lang.Comparable接口,并且重写comparaTo()方法,返回0则表示是同一个对象,否则为不同对象。

      ②客户排序:建立一个第三方类并实现java.util.Comparator接口。并重写方法。定义集合形式为TreeSet ts = new TreeSet(new 第三方类());

    下面一个例子用TreeSet存放自然排序的对象:

    复制代码
     1 package com.set;
     2 
     3 import java.util.Set;
     4 import java.util.TreeSet;
     5 
     6 class Student1 implements Comparable<Student1>{
     7     int id;
     8     public Student1(int id) {
     9         this.id = id;
    10     }
    11     @Override
    12     public String toString() {
    13         return this.id+"";
    14     }
    15     @Override
    16     public int hashCode() {
    17         return this.id;
    18     }
    19     @Override
    20     public boolean equals(Object obj) {
    21         if (obj instanceof Student1){
    22             Student1  stu = (Student1) obj;
    23             if (stu.id == this.id)
    24                 return true;
    25         }
    26         return false;
    27     }
    28     public int compareTo(Student1 o) {
    29         return (this.id-o.id);
    30     }
    31 }
    32 
    33 public class TreeSetTest {
    34     public static void main(String[] args) {
    35         Set<Student1> set = new TreeSet<Student1>();
    36         Student1 s1 = new Student1(5);
    37         Student1 s2 = new Student1(1);
    38         Student1 s3 = new Student1(2);
    39         Student1 s4 = new Student1(4);
    40         Student1 s5 = new Student1(3);
    41         set.add(s1);
    42         set.add(s2);
    43         set.add(s3);
    44         set.add(s4);
    45         set.add(s5);
    46         for (Student1 s : set) {
    47             System.out.println(s);
    48         }
    49     }
    50 
    51 }
    复制代码

    输出结果为:
    1
    2
    3
    4
    5

    下面一个例子用TreeSet存放客户排序的对象:

    复制代码
     1 package com.set;
     2 
     3 import java.util.Set;
     4 import java.util.TreeSet;
     5 
     6 class MySort implements java.util.Comparator<Student2>{
     7 
     8     public int compare(Student2 o1, Student2 o2) {
     9         return o2.id-o1.id;
    10     }
    11 }
    12 class Student2{
    13     int id;
    14     public Student2(int id) {
    15         this.id = id;
    16     }
    17     @Override
    18     public String toString() {
    19         return this.id+"";
    20     }
    21     @Override
    22     public int hashCode() {
    23         return this.id;
    24     }
    25     @Override
    26     public boolean equals(Object obj) {
    27         if (obj instanceof Student2){
    28             Student2  stu = (Student2) obj;
    29             if (stu.id == this.id)
    30                 return true;
    31         }
    32         return false;
    33     }
    34 }
    35 public class TreeSetTest2 {
    36     public static void main(String[] args) {
    37         Set<Student2> set = new TreeSet<Student2>(new MySort());
    38         Student2 s1 = new Student2(5);
    39         Student2 s2 = new Student2(1);
    40         Student2 s3 = new Student2(2);
    41         Student2 s4 = new Student2(4);
    42         Student2 s5 = new Student2(3);
    43         set.add(s1);
    44         set.add(s2);
    45         set.add(s3);
    46         set.add(s4);
    47         set.add(s5);
    48         for (Student2 s : set) {
    49             System.out.println(s);
    50         }
    51     }
    52 
    53 }
    复制代码

    输出结果为:
    5
    4
    3
    2
    1

    大家都知道List存放时按照插入顺序排序的,其实也可以用自然排序和客户排序对List集合排序,大家请看:

    复制代码
     1 package com.set;
     2 
     3 import java.util.ArrayList;
     4 import java.util.Collections;
     5 import java.util.List;
     6 
     7 class MySort1 implements java.util.Comparator<Student3>{
     8     public int compare(Student3 o1, Student3 o2) {
     9         return o2.id-o1.id;
    10     }
    11 }
    12 class Student3 implements Comparable<Student3>{
    13     int id;
    14     public Student3(int id) {
    15         this.id = id;
    16     }
    17     @Override
    18     public String toString() {
    19         return this.id+"";
    20     }
    21     public int compareTo(Student3 o) {
    22         return (this.id-o.id);
    23     }
    24 }
    25 
    26 public class ListSort {
    27     public static void main(String[] args) {
    28         List<Student3> list = new ArrayList<Student3>();
    29         Student3 s1 = new Student3(5);
    30         Student3 s2 = new Student3(1);
    31         Student3 s3 = new Student3(2);
    32         Student3 s4 = new Student3(4);
    33         Student3 s5 = new Student3(3);
    34         list.add(s1);
    35         list.add(s2);
    36         list.add(s3);
    37         list.add(s4);
    38         list.add(s5);
    39         System.out.println(list);
    40         //自然排序:
    41         Collections.sort(list);
    42         System.out.println(list);
    43         //客户排序
    44         Collections.sort(list, new MySort1());
    45         System.out.println(list);
    46     }
    47 }
    复制代码

    输出结果为:
    [5, 1, 2, 4, 3]
    [1, 2, 3, 4, 5]
    [5, 4, 3, 2, 1]

      3.LinkedHashSet

      LinkedHashSet按照插入顺序保存对象,同时还保存了HashSet的查询速度。

  • 相关阅读:
    logging——日志——转载02
    logging——日志——转载03
    c# 整型数据与字符串 的之间互换(原创)
    收到邮件且自动发送到对方提供的邮箱
    学习了1!+...10!
    Outlook 2003 Add in 部署笔记
    学会了调用方法
    c# 属性的作用
    (转)软件的围城,谈高级语言的学习(一位架构师的忠告!)
    常用命令控制行
  • 原文地址:https://www.cnblogs.com/TQCAI/p/7638552.html
Copyright © 2011-2022 走看看