treeSet的特点:不可重复可排序
使用treeSet进行排序的时候,需要注意的地方:
1、在使用treeSet进行排序的时候,如果数据不能排序会报cannot be cast to java.lang.Comparable
2、对于不能排序的数据,有两种方法可以实现排序:
a、对于排序的实体类实现java.lang.comparable接口重写compareTo方法
public class Person implements Comparable<Person> {
//姓名
private String name;
//帅气指数
private int handsome;
public Person() {
}
public Person(String name, int handsome) {
super();
this.name = name;
this.handsome = handsome;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getHandsome() {
return handsome;
}
public void setHandsome(int handsome) {
this.handsome = handsome;
}
@Override
public String toString() {
return "姓名:"+this.name+"\t帅气指数:"+this.handsome;
}
@Override
public int compareTo(Person o) {
//根据帅气指数进行降序排序,若要进行升序在前面加一个负号
return (o.handsome - this.handsome);
}
}
b、新增一个业务类实现java.util.comparator接口重写compare方法
public class PersonSort implements java.util.Comparator<Person> {
@Override
public int compare(Person o1, Person o2) {
/*
* 根据帅气指数进行升序排序,如果要降序则在前面加一个负号
* 怎么使用:在new TreeSet(new PersonSort());
*/
return (o1.getHandsome()-o2.getHandsome());
}
}
使用treeSet需要注意的地方:
1、使用treeSet在排序的时候是在添加的时候进行排序的,如果在添加之后修改数据不会影响前面的排序
2、在使用treeSet的时候,如果是在添加数据之后修改数据的值,可能会出现一样的数据
3、为了避免这种情况的发生,可以将对象的属性用final修饰