Com*_*erd 4 java sorting debugging comparator
我正在尝试通过长类型的对象属性NodeID对对象进行排序。
Collections.sort(PeerNodeInChord, new Comparator<PeerNode>()
{
@Override public long compare(PeerNode p1, PeerNode p2)
{
return p1.NodeID - p2.NodeID; // Ascending
}
});
Run Code Online (Sandbox Code Playgroud)
我收到以下错误:
中的compare(PeerNode,PeerNode)无法实现Comparator返回类型中的compare(T,T)long与int不兼容,其中T是类型变量:T扩展了在接口Comparator中声明的对象
似乎我不能将类型“ long”作为返回类型,而必须将“ int”作为返回类型。
我不允许将NodeID类型更改为int。
有什么方法可以通过对象属性NodeID来对PeerNode的ArrayList进行排序,该属性是长类型的?
不要重新发明轮子,只需将委托委托给compare来自的方法Long:
@Override
public int compare(PeerNode p1, PeerNode p2) {
return Long.compare(p1.NodeID, p2.NodeID);
}
Run Code Online (Sandbox Code Playgroud)
出于好奇,您可以看一下Long.compare实现:
public static int compare(long x, long y) {
return (x < y) ? -1 : ((x == y) ? 0 : 1);
}
Run Code Online (Sandbox Code Playgroud)
Collections.sort(PeerNodeInChord, new Comparator<PeerNode>() {
@Override
public int compare(PeerNode p1, PeerNode p2) {
long dif = p1.NodeID - p2.NodeID;
if (dif > 0) return 1;
if (dif < 0) return -1;
return 0;
}
});
Run Code Online (Sandbox Code Playgroud)