A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 林国锋 黑马帝   /  2011-10-6 23:47  /  2510 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

有一个Set集合,现在是按年龄从小到大排序,现在想按年龄从大到小排序,请问用强行逆转排序怎么实现?
Set<Student> stus = new TreeSet<Student>();
suts.add(new Student("张三",18))
suts.add(new Student("大七",22))
suts.add(new Student("周六",24))
suts.add(new Student("小四",28))
suts.add(new Student("王五",35))

2 个回复

倒序浏览
本帖最后由 张校云 于 2011-10-7 00:01 编辑

原来是TreeSet,看错了 ,以为是List呢
回复 使用道具 举报
可以使用集合的扩展类Collections的reerseOrder方法,此方法的定义如下:
static <T> Comparator<T> reverseOrder(Comparator<T> cmp)
         此方法 返回一个比较器,它强行逆转指定比较器的顺序。
你上面的代码可以写成如下形式:
Set<Student> stus = new TreeSet<Student>();
suts.add(Collections.reverseOrder(new Student("张三",18)));
suts.add(Collections.reverseOrder(new Student("大七",22)));
suts.add(Collections.reverseOrder(new Student("周六",24)));
suts.add(Collections.reverseOrder(new Student("小四",28)));
suts.add(Collections.reverseOrder(new Student("王五",35)) );
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马