按字母顺序对基于其成员项的“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());
如果您对它感兴趣,请查看:
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方法。