java笔记四:Set接口

java

  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的查询速度。

以上是 java笔记四:Set接口 的全部内容, 来源链接: utcz.com/z/391810.html

回到顶部