通常,需要按照一定的规则或顺序将某些数据取出来,这时,就需要用到treeset集合,其方式有两种:
方式一、使用Comparable,用所输出元素的此类对象实现 Comparable这个接口,实现compareTo()这个方法即可
方式二、使用比较器,用一个实现类,来实现Comparator这个接口,实现的是compare这个方法
注意:为了保证编译的时候不会报一些未处理的安全错误提示,要是使用泛型(如本例中的TreeSet的创建的时候,有泛型),如下图所示的错误:
import java.util.*;
public static void main( String[] arg){
//加入比较器
NameComparator nc=new NameComparator();
TreeSet<Student> set=new TreeSet<Student> (nc);
set.add(new Student(1,"james"));
set.add(new Student(23,"jame33s"));
set.add(new Student(344,"james33"));
set.add(new Student(41,"james4444"));
Iterator it =set.iterator();
while (it.hasNext()){
Student s= (Student)it.next();
System.out.println(s.getNum()+"..."+s.getName());
}
}
}
class NameComparator implements Comparator<Student>{
public int compare(Student s1,Student s2){
int i =s1.getName().length()-s2.getName().length();
if(i==0){
return s1.getNum()-s2.getNum();
}
return i;
}
}
//由于这个是该类的内部实现,不能失去的排序顺序,要实现的是按照名字排序,意思是不能修改这个方法,只能是用比较器(创建一个比较器,是实现Comparator这个接口)
int num;
String name;
public Student(int num,String name){
this.num=num;
this.name=name;
}
public void setName(String name){
this.name=name;
}
public String getName(){
return this.name;
}
public void setNum(int num){
this.num=num;
}
public int getNum(){
return this.num;
}
public int compareTo(Student s){
return this.getNum()-s.getNum();
}
}