按字母顺序对基于其成员项的“toString”值的Java Collection进行排序

假设我有一个名为Foo的用户定义的Java类,例如:

public class Foo { private String aField; @Override public String toString() { return aField; } } 

和一个集合,如:

 List aList; 

我想要做的是根据每个成员返回的’.toString()’值按字母顺序对列表进行排序。

我已经尝试使用Collections.sort()方法,但结果不是我正在尝试的。 为了做到这一点,我需要做什么?

使用指定比较器的API sort(List list, Comparator c) ,并按您的意愿实现。

或者,如果您不特别需要List,请使用SortedSet ,与比较器相同。

 Collections.sort(fooList, new Comparator() { public int compare(Foo f1, Foo f2) { return f1.toString().compareTo(f2.toString()); } }); 

假设toString永远不会返回null,并且列表中没有空项。

通过订购, google-collections非常简单:

 Collections.sort(list, Ordering.usingToString()); 

引入一个完整的第三方库只是为了使用一些你可以使用Comparator(正如其他人提供的那样)值得写的东西值得吗? 不,但谷歌collections是如此酷,你会想要它还有其他一些原因。

在排序方面,您还可以轻松完成倒车等操作:

 Ordering.usingToString().reverse(); 

或打破关系:

 Ordering.usingToString().compound(someOtherComparator); 

或处理空值:

 Ordering.usingToString().nullsFirst(); 

等等,但是那里有更多的东西(当然不仅仅是排序相关的)才能产生真正富有表现力的代码。 看看这个!

 public class Foo implements Comparable { private String aField; public Foo(String s) { aField=s; } public String getAField() { return aField; } public int compareTo(Foo other) { return getAField().compareTo(other.getAField()); } @Override public String toString() { return getAField(); } } 

接着

Collections.sort(名单);

我会做一些与皮埃尔非常相似的事情:

 public class Foo implements Comparable { private String aField; @Override public String toString() { return aField; } public int compareTo(Foo o) { return this.toString().compareTo(o.toString()); } } 

然后,像皮埃尔一样,我会像皮埃尔建议的那样使用Collections.sort(list)

我强烈建议你只使用toString进行调试……但是……要扩展Yuval A在上面写的内容……

公共课X.
    实现比较器
 {
     public int compare(final Foo a,final Foo b) 
     {
         return(a.toString()。compareTo(b.toString()));
     }
 }

但是你真的应该让Foo实现Comarable或编写一个不使用toString的正确的Compartor。

lambdaj允许您排序,过滤和一般操作集合,而无需编写循环或模糊内部类。 例如,您要求的排序可以如下实现:

 sort(foos, on(Foo.class).toString()); 

如果您对它感兴趣,请查看:

http://code.google.com/p/lambdaj/

Java 8版本:

 list.sort(Comparator.comparing(Object::toString)); 

或流媒体:

 List sortedList = unsortedList .stream() .sorted(Comparator.comparing(Object::toString))) .collect(Collectors.toList()); 

如果您希望对集合保持排序,而不是在特定点对其进行排序,则可以将其放在具有已定义的Comparator的TreeSet中。 否则,我将使用Yuval已经提到的Collections.sort方法。