java set接口特点_java中set接口的用法

java中的set接口有如下的特点:

不允许出现重复元素;

集合中的元素位置无顺序;

有且只有一个值为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,则是同一个对象,不能重复存放。

packagecn.set;importjava.util.HashSet;importjava.util.Set;classStudent{intid;public Student(intid) {this.id =id;

}

@OverridepublicString toString() {return this.id+"";

}

@Overridepublic inthashCode() {return this.id;

}

@Overridepublic booleanequals(Object obj) {if (obj instanceofStudent){

Student stu=(Student) obj;if (stu.id == this.id)return true;

}return false;

}

}public classHashSetTest {public static voidmain(String[] args) {

Set set = new HashSet();

Student s1= new Student(1);

Student s2= new Student(1);

Student s3= new Student(2);

set.add(s1);

set.add(s2);

set.add(s3);for(Student s : set) {

System.out.println(s);

}

}

}

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

2.TreeSet

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

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

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

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

packagecn.set;importjava.util.Set;importjava.util.TreeSet;class Student1 implements Comparable{intid;public Student1(intid) {this.id =id;

}

@OverridepublicString toString() {return this.id+"";

}

@Overridepublic inthashCode() {return this.id;

}

@Overridepublic booleanequals(Object obj) {if (obj instanceofStudent1){

Student1 stu=(Student1) obj;if (stu.id == this.id)return true;

}return false;

}public intcompareTo(Student1 o) {return (this.id-o.id);

}

}public classTreeSetTest {public static voidmain(String[] args) {

Set set = new TreeSet();

Student1 s1= new Student1(5);

Student1 s2= new Student1(1);

Student1 s3= new Student1(2);

Student1 s4= new Student1(4);

Student1 s5= new Student1(3);

set.add(s1);

set.add(s2);

set.add(s3);

set.add(s4);

set.add(s5);for(Student1 s : set) {

System.out.println(s);

}

}

}

输出结果为:

1

2

3

4

5

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

packagecom.set;importjava.util.Set;importjava.util.TreeSet;class Student1 implements Comparable{intid;public Student1(intid) {this.id =id;

}

@OverridepublicString toString() {return this.id+"";

}

@Overridepublic inthashCode() {return this.id;

}

@Overridepublic booleanequals(Object obj) {if (obj instanceofStudent1){

Student1 stu=(Student1) obj;if (stu.id == this.id)return true;

}return false;

}public intcompareTo(Student1 o) {return (this.id-o.id);

}

}public classTreeSetTest {public static voidmain(String[] args) {

Set set = new TreeSet();

Student1 s1= new Student1(5);

Student1 s2= new Student1(1);

Student1 s3= new Student1(2);

Student1 s4= new Student1(4);

Student1 s5= new Student1(3);

set.add(s1);

set.add(s2);

set.add(s3);

set.add(s4);

set.add(s5);for(Student1 s : set) {

System.out.println(s);

}

}

}

输出结果为:

5

4

3

2

1

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

packagecn.set;importjava.util.ArrayList;importjava.util.Collections;importjava.util.List;class MySort1 implements java.util.Comparator{public intcompare(Student3 o1, Student3 o2) {return o2.id-o1.id;

}

}class Student3 implements Comparable{intid;public Student3(intid) {this.id =id;

}

@OverridepublicString toString() {return this.id+"";

}public intcompareTo(Student3 o) {return (this.id-o.id);

}

}public classListSort {public static voidmain(String[] args) {

List list = new ArrayList();

Student3 s1= new Student3(5);

Student3 s2= new Student3(1);

Student3 s3= new Student3(2);

Student3 s4= new Student3(4);

Student3 s5= new Student3(3);

list.add(s1);

list.add(s2);

list.add(s3);

list.add(s4);

list.add(s5);

System.out.println(list);//自然排序:

Collections.sort(list);

System.out.println(list);//客户排序

Collections.sort(list, newMySort1());

System.out.println(list);

}

}

输出结果为:

[5, 1, 2, 4, 3]

[1, 2, 3, 4, 5]

[5, 4, 3, 2, 1]

此文转载自:http://www.cnblogs.com/liuling/archive/2013/04/16/set.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值