1. TreeSet的使用
1.1 使用说明:
1.1.1向TreeSet中添加的数据,要求是相同类的对象。
1.1.2两种排序方式:自然排序 ---- 实现Comparable接口 和 定制排序(Comparator)
注意:TreeSet自然排序中比较两个对象是否相同的标准是: compareTo()返回0(不再是equals())
1) 自然排序中,比较两个对象是否相同的标准为:compareTo()返回0.不再是equals().
2) 定制排序中,比较两个对象是否相同的标准为:compare()返回0.不再是equals().
2常用的排序方式:
//方式一:自然排序
@Test
public void test1(){
TreeSet set = new TreeSet();
//失败:不能添加不同类的对象
// set.add(123);
// set.add(456);
// set.add("AA");
// set.add(new User("Tom",12));
//举例一:从小到大
// set.add(34);
// set.add(-34);
// set.add(43);
// set.add(11);
// set.add(8);
//举例二:报错
set.add(new User("Tom",12));
set.add(new User("Jerry",32));
set.add(new User("Jim",2));
set.add(new User("Mike",65));
set.add(new User("Jack",33));
set.add(new User("Jack",56));
Iterator iterator = set.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}
}
//方式二:定制排序
@Test
public void test2(){
Comparator com = new Comparator() {
//照年龄从小到大排列
@Override
public int compare(Object o1, Object o2) {
if(o1 instanceof User && o2 instanceof User){
User u1 = (User)o1;
User u2 = (User)o2;
return Integer.compare(u1.getAge(),u2.getAge());
}else{
throw new RuntimeException("输入的数据类型不匹配");
}
}
};
TreeSet set = new TreeSet(com);
set.add(new User("Tom",12));
set.add(new User("Jerry",32));
set.add(new User("Jim",2));
set.add(new User("Mike",65));
set.add(new User("Mary",33));
set.add(new User("Jack",33));
set.add(new User("Jack",56));
Iterator iterator = set.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}
}
这篇博客介绍了Java中的TreeSet集合,重点讲述了如何进行自然排序和定制排序。在自然排序中,对象通过实现Comparable接口来确定顺序,而在定制排序中,通过Comparator接口进行自定义比较规则。文章提供了两个示例,一个是按照User对象的年龄自然排序,另一个是通过Comparator实现年龄定制排序。
372

被折叠的 条评论
为什么被折叠?



