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 set = new HashSet();
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{
 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 set = new TreeSet();
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{
 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 set = new TreeSet(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{
 8     public int compare(Student3 o1, Student3 o2) {
 9         return o2.id-o1.id;
10     }
11 }
12 class Student3 implements Comparable{
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 list = new ArrayList();
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的查询速度。

时间: 2024-09-13 22:21:53

java笔记四:Set接口的相关文章

《java与模式》笔记-----抽象类和接口

笔记 抽象类和接口 什么是接口:接口就是一些方法特征的集合------接口是对抽象的抽象. 什么是抽象类:抽象类对某具体类型的部分实现------抽象类是对具体的抽象. 方法特征包括:方法的名字.参数的数目.参数的类型.不包括:返回类型.参数名字.和抛出的异常. 接口是类型转换的前提.是动态调用的保证.实现某一接口就完成了类型的转换(多重继承):动态调用只关心类型,不关心具体类.          -------------------------------------------------

java笔记三:List接口

List承诺可以将元素维护在特定的序列中.List接口在Collection的基础上添加了大量的方法,使得可以在List的中间插入和删除元素.List与 set 不同,列表通常允许重复的元素.并且存放的顺序与插入的顺序一致. List接口的常用方法有: **[add](http://www.cnblogs.com/java/util/List.html#add(E))**([E](http://www.cnblogs.com/java/util/List.html "List 中的类型参数&qu

接口继承-关于java中Dao模块接口问题,请教一下原理

问题描述 关于java中Dao模块接口问题,请教一下原理 BaseDao.java public interface BaseDao {} BaseDaoImpl.java public abstract class BaseDaoImpl implements BaseDao {} UserService.java public interface UserService extends BaseDao{} UserServiceImpl.java public class UserServi

java中监听接口里面的onclick方法为什么被称为回调方法

问题描述 java中监听接口里面的onclick方法为什么被称为回调方法 那普通接口有回调方法吗,普通类有回调方法吗, 回调方法是如何定义的 解决方案 你别被回调这个词搞蒙了,其实就是把方法当做参数而已 解决方案二: 因为onclick你定义了,不是自己调用,而是间接由按钮点击后系统类库去调用,所以叫回调. 英文叫做callback. 解决方案三: 回调方法简单的说就是a方法都用b方法,b方法执行过程中需要调用a方法,callback 解决方案四: [个人向]Android回调接口的实现方法ja

java中实现Serializable接口的类有什么特点?

问题描述 java中实现Serializable接口的类有什么特点? java中实现Serializable接口的类有什么特点,还看到这个实现该接口的类里面一个常量,private static final long serialVersionUID = 1L;如何理解这个常量呢 解决方案 Serializable是一个标识接口,没有需要实现的方法,凡是实现该接口的类都可以进行序列化和反序列化操作. 实现serializable接口的作用是就是可以把对象存到字节流,然后可以恢复.所以你想如果你的

列表-关于JAVA中的List接口

问题描述 关于JAVA中的List接口 有如下说明代码 class A{} main() { Listall=ArrayList(); all.add(new A()); all.add(new A()); A[] a1=new A[2]; a1=(A[])all.toArray(); A[] a2=all.toArray(new A[]{}); } 以上代码, a1=(A[])all.toArray();总是报ClassCastException错误, 而toArray()方法返回的是Obje

asp调用java 写的webservice接口怎么用啊!(在线等)

问题描述 路过的各位朋友,asp调用java写的webservice接口怎么用啊!一个很简单的例子,就是传个参数进去,然后返回出来就可以了! 解决方案 解决方案二:根据权威机构的调查,搜索引擎的前4名网站一般会获得较高的访问量.但是如果想要使自己的网站排在前4名,竞价花费的价格是非常高的.而花费少的话,网站排名靠后,导致竞价排名的效果大打折扣.毫无疑问,每个客户都希望自己的网站排在搜索引擎的首页,但是同样是页,第一名和第十名的竞价价格也许会2倍甚至更多.对于大多说发展期的公司来说,往往需要抉择选

MongoDB快速入门笔记(四)之MongoDB查询文档操作实例代码_MongoDB

MongoDB简介 MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的. 下面给大家介绍MongoDB查询文档操作的实例 先把student删除,再重新插入数据 > db.student.drop() true > db.student.insert([{ "_id" : 1, "

asp怎么访问java的短信接口

 asp 如何访问java的短信接口 对方程序是java做的,提供了一个地址,还有用户名,密码 说往这里传参数就可以发短信,我用ie直接访问此地址,看到的是一个xml文件asp这边需要如何传递短信的一些参数还有用户名密码给对方呢希望别贴教程,点拨一下最好,因为我从网上找了一些范例,但总是只返回状态200 ok 没有任何返回值,也没有发送成短信,所以不知道为什么了用户名密码是用来识别是谁要调用此接口发短信对方提供的url地址 http://10.13.255.196/SmsDownlinkRece