实现比较器接口以实现对象的自然排序:
如果我们有班级帐户:
class Account
{
Account(String name, int id)
int balance()
void deposit(int n)
}
我们想按顺序对两个帐户的帐户余额进行排序
这两种方法之间的差异是什么?
public class comparebalances implements Comparable <Account>
{
public int compare (Account acc1, Account acc2)
{
return acc1.balance()-acc2.balance();
}
}
public class comparebalances implements Comparable <Account>
{
public int compare (Account acc1, Account acc2)
{
if (acc1.balance()> acc2.balance())
return 1;
else if (acc1.balance()< acc2.balance())
return -1;
else if (acc1.balance()==acc2.balance())
return 0;
}
}
答案 0 :(得分:3)
第二个更安全,因为第一个可以为极值(整数溢出)提供错误的结果。
答案 1 :(得分:3)
正如Puce已经写过的那样,第二个是更安全的,其中Integer溢出会给你意想不到的输出。如果您希望它同时简短安全,您可以写下:
return Integer.compare(acc1.balance(), acc2.balance());