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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© L.I.F.E 中级黑马   /  2013-5-29 16:12  /  1479 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 L.I.F.E 于 2013-5-30 07:30 编辑
  1. import java.util.*;
  2. //自定义一个比较器,实现comparator接口。
  3. class StrComparator implements Comparator<String>
  4. {
  5. public int compare(String s1,String s2)
  6. {
  7. return s2.compareTo(s1);
  8. }
  9. }
  10. class CollectionsDemo3
  11. {
  12. public static void main(String[] args)
  13. {
  14. orderDemo();
  15. }
  16. public static void orderDemo()
  17. {
  18. //TreeSet<String> ts = new TreeSet<String>(new StrComparator());//  这里属于匿名内部类?
  19. TreeSet<String> ts = new TreeSet<String>(Collections.reverseOrder());//这里是什么呢?
  20. ts.add("avddd");
  21. ts.add("ddd");
  22. ts.add("vdd");
  23. ts.add("mvddd");
  24. Iterator<String> it = ts.iterator();
  25. while (it.hasNext())
  26. {
  27. sop(it.next());
  28. }

  29. }
  30. public static void sop(Object obj)
  31. {
  32. System.out.println(obj);
  33. }
  34. }
复制代码
具体是怎么操作的呢?

评分

参与人数 1技术分 +1 收起 理由
袁梦希 + 1 很给力!

查看全部评分

1 个回复

正序浏览
//TreeSet<String> ts = new TreeSet<String>(new StrComparator());//  这里属于匿名内部类?
TreeSet的构造方法可以接收一个比较器,可以是自定义的,也就是StrComparator()
具体怎样操作,上面也有写了,写一个类实现Comparator接口,然后覆盖compara方法


TreeSet<String> ts = new TreeSet<String>(Collections.reverseOrder());//这里是什么呢?
也可以是Collections.reverseOrder()方法,返回一个强行逆转默认排序的比较器
这个建议看看API

评分

参与人数 1技术分 +1 收起 理由
袁梦希 + 1 很给力!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马