java Set接口与常用子类

Set :元素是无序的(存入和取出顺序不一定一致),不能重复,更确切地讲,Set 不包含满足 e1.equals(e2) 的元素对 e1 和 e2

Set已实现的子类:

HashMap:底层数据结构为哈希表 线程非同步
     保证元素唯一性:
HashSet:是通过元素的两个方法,hashCodet 与equals来完成的唯一性的
    如果元素的HashCode值相同,才会判断equals是否为true;
    如果元素的hashcode值不同,不会调用equals。
    注意:对于判断元素是否存在,以有删除等操作,依赖的方法是元素的hashcode和equals方法。

TreeSet:可以对Set集合中的元素进行排序,底层数据结构是二叉树。
          保证元素唯一性的依据:compareTo方法return 0

TreeSet :排序的第一种方式:让元素自身具备比较性。
    元素需要实现comparable口,覆盖compareTo方法。
    这种方式也成为元素的自然顺序,或者叫做默认顺序
TreeSet:排序的第二种方式:
TreeSet(Comparator<? super E> comparator) //构造一个新的空 TreeSet,它根据指定比较器进行排序。
当元素自身不具备比较性时,或都具备的比较性不是所需要的
这时就需要让集合自身具备比较性。在集合初始化时,就有了比较方式。定义比较器,将比较器对象作为参数传给集合构造参数。让集合自身具备比较性。当两种都存在时以比较器为准。

示例:

class Person implements Comparable<Person> {

	private String name;
	private int age;

	public Person(String name, int age) {
		super();
		this.name = name;
		this.age = age;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}

	@Override
	public int compareTo(Person o) {
		if (!(o instanceof Person)) {
			throw new ClassCastException("类型不匹配");
		}
		int num = new Integer(this.age).compareTo(new Integer(o.age));
		if (num == 0) {
			return this.name.compareTo(o.name);
		}
		return num;
	}

	@Override
	public String toString() {
		// TODO Auto-generated method stub
		return name + ":" + age;
	}
}

//比较器
class MyCompare implements Comparator {

	@Override
	public int compare(Object o1, Object o2) {
		Person p1 = (Person) o1;
		Person p2 = (Person) o2;
		int num = p1.getName().compareTo(p2.getName());
		if (num == 0) {
			return new Integer(p1.getAge()).compareTo(new Integer(p2.getAge()));
		}
		return num;
	}

}
<pre name="code" class="java">TreeSet<Person> set = new TreeSet<Person>();
		set.add(new Person("aa", 4));
		set.add(new Person("ba", 45));
		set.add(new Person("ra", 4));
		set.add(new Person("bd", 6));

		Iterator<Person> iterator = set.iterator();
		while (iterator.hasNext()) {
			Person p = iterator.next();
			System.out.println(p);
		}

		System.out
				.println("==================================================");
		TreeSet<Person> set1 = new TreeSet<Person>(new MyCompare());
		set1.add(new Person("aa", 4));
		set1.add(new Person("ja", 45));
		set1.add(new Person("ha", 4));
		set1.add(new Person("bd", 6));

		Iterator<Person> iterator1 = set1.iterator();
		while (iterator1.hasNext()) {
			Person p = iterator1.next();
			System.out.println(p);
		}

	}


 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值