Ric*_*ard 4 java sorting collections android comparator
我创建了一个自定义Comparator来对字符串的ArrayList进行排序.我已通过调试器运行它并观察它正确比较和返回值.但是,我的数组没有排序.由于我是Java和Android的新手,可能还会有其他事情发生.
看了几个小时后,我无法弄清楚是什么......因为我一直在用这个网站回答这么多其他问题,我知道该去哪里!
Collections.sort(allWords, new Comparator<String>(){
public int compare(String o1, String o2) {
scoreWord sc1 = new scoreWord((String)o1);
scoreWord sc2 = new scoreWord((String)o2);
int i1 = sc1.getScore();
int i2 = sc2.getScore();
if ( i1 > i2 )
return 1;
return 0;
}
public boolean equals(String o1, String o2) {
scoreWord sc1 = new scoreWord((String)o1);
scoreWord sc2 = new scoreWord((String)o2);
int i1 = sc1.getScore();
int i2 = sc2.getScore();
if ( i1 == i2 )
return true;
return false;
}
});
Run Code Online (Sandbox Code Playgroud)
Jon*_*eet 20
您的compare方法不对称 - 它始终返回1或0.
相反,只需委托Integer.compare(如果它在你正在使用的Java版本中可用),传入分数:
public int compare(String o1, String o2) {
scoreWord sc1 = new scoreWord((String)o1);
scoreWord sc2 = new scoreWord((String)o2);
return Integer.compare(i1, i2);
}
Run Code Online (Sandbox Code Playgroud)
否则手工做,坦白说是痛苦 - 如果你需要在不止一个地方,我建议你编写自己的实现,Integer.compare以避免重复:
public int compare(String o1, String o2) {
scoreWord sc1 = new scoreWord((String)o1);
scoreWord sc2 = new scoreWord((String)o2);
return i1 > i2 ? 1
: i1 < i2 ? -1
: 0;
}
Run Code Online (Sandbox Code Playgroud)
这样你就会有适当的对称性:
a.compareTo(b) < 0 暗示 b.compareTo(a) > 0a.compareTo(b) > 0 暗示 b.compareTo(a) < 0a.compareTo(b) == 0 暗示 b.compareTo(a) == 0hom*_*ome 12
试试这个:
public int compare(String o1, String o2) {
scoreWord sc1 = new scoreWord((String)o1);
scoreWord sc2 = new scoreWord((String)o2);
int i1 = sc1.getScore();
int i2 = sc2.getScore();
if ( i1 > i2 ) {
return 1;
} else if ( i1 < i2 ) {
return -1;
} else {
return 0;
}
}
Run Code Online (Sandbox Code Playgroud)