[英]Sorting Strings using Collections.sort?
我正在尝试使用collection.sort()方法对两个字符串进行排序,但是我在理解实现的逻辑时遇到了问题。 这是我到目前为止所拥有的。 我的实施有问题吗? 注意:我想按字母顺序对它们进行排序:“Apple”>“Orange”
Collections.sort(mailbox.getMessages() , (String a, String b) -> {
if (String.valueOf(a.charAt(0)) > String.valueOf(b.charAt(0))) {
return -1;
}
else if (String.valueOf(a.charAt(0)) <
String.valueOf(b.charAt(0))) {
return 1;
}
else {
return 0;
}
});
String
实现了一个Comparable<String>
,它实现为字典比较,换句话说,默认为"Apple".compareTo("Orange") < 0
。 所以默认就足够了。
现在Collections.sort
有一个变量,它将这个比较器考虑在内,你可以简单地使用:
Collections.sort(mailbox.getMessages());
关于您自己的实施:
你不应该使用String.valueof
来String.valueof
转换为字符串:你可以将char
与<
s进行比较,但是你不能在String
上使用这个运算符。 此外,您的实现不是递归的 :如果两个第一个字符相等,那并不意味着String
本身是相等的,例如"Apple"
和"Ambiguous"
。 所以你必须实现一个更复杂的比较器。
您无法将String
与符号>
进行比较。 你可以简单地做:
Collections.sort(mailbox.getMessages(), (String a, String b) -> {
return Character.compare(a.charAt(0), b.charAt(0));
});
请注意,这将仅根据第一个字符排序。 如果要以词法方式对整个字符串值进行排序,那么您可以简单地使用Collections.sort(mailbox.getMessages())
因为String
已经实现了Comparable
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.