Foo*_*ish 1 java sorting collections list comparator
我有一份清单
List<String> names = new ArrayList<String>();
names.add("One");
names.add("Two");
names.add("Three");
names.add("Six");
names.add("Four");
names.add("Five");
Run Code Online (Sandbox Code Playgroud)
我想要这个列表排序,以便Six首先出现,然后它应该按字母顺序排列.
names.sort((x, y) -> {
if (x.startsWith("S"))
return -1;
if (y.startsWith("S"))
return 1;
return x.compareTo(y);
});
Run Code Online (Sandbox Code Playgroud)
这很好用.为什么它不适用于唯一的x.startswith("S")条件.为什么我需要添加条件y.startsWith("S")
您不知道sort算法将以何种顺序比较您的Strings.它可能会打电话compare("Two","Six"),它可能会打电话compare("Six","Two").因此,您Comparator必须支持这两种情况.
此外,在没有检查startsWith("S")第一个和第二个参数的情况下,您违反了Comparator合同,这需要这样做sgn(compare(x, y)) == -sgn(compare(y, x)).
顺便说一句,最好检查equals("Six")而不是startsWith("S").否则,如果您的输入包含"Seven",则代码将失败.