TreeSet分析

1. |——SortedSet接口——TreeSet实现类
Set接口-|——HashSet实现类
|——LinkedHashSet实现类
我们知道Set接口不保证集合的迭代顺序,TreeSet的出现弥补了这一问题,根据使用的构造
方法不同,可能会按照元素的自然顺序进行排序,或按照在创建 set 时所提供的比较器进行排序。让我们来看一个小例子

import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet;


public class TreeSetTest {

public static void main(String[] args) {
TreeSet set = new TreeSet(new PersonComparator());
Person person1 = new Person(20);
Person person2 = new Person(40);
Person person3 = new Person(30);
Person person4 = new Person(10);
set.add(person1);
set.add(person2);
set.add(person3);
set.add(person4);

for(Iterator it = set.iterator();it.hasNext();){
Person person = (Person)it.next();
System.out.println(person.getScore());
}

//我们可以根据自己定义的比较器来取得集合的最大对象
System.out.println(Collections.max(set,new PersonComparator()));
}

}

class Person {
private int score;
public Person(int score){
this.score = score;
}
public int getScore() {
return score;
}
public void setScore(int score) {
this.score = score;
}

@Override
public String toString() {
return String.valueOf(this.score);
}

//重写equals方法和hashCode方法,避免集合中出现属性值相同的对象
@Override
public int hashCode() {
final int PRIME = 31;
int result = 1;
result = PRIME * result + score;
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
final Person other = (Person) obj;
if (score != other.score)
return false;
return true;
}
}

class PersonComparator implements Comparator{

public int compare(Object o1, Object o2) {
Person person1 = (Person)o1;
Person person2 = (Person)o2;
//按照score的值升序排序
return person1.getScore() - person2.getScore();
}

}


当然HashSet是基于Hash算法实现的,其性能通常优于TreeSet,我们通常都应该使用HashSet,在我们需要排序的功能时,我门才使用TreeSet
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值