3

在实现比较器接口以实现对象的自然排序时:

说如果我们有类帐户:

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;
     }

}
4

2 回答 2

3

正如 Puce 已经写的那样,第二个更安全,因为整数溢出会给你带来意想不到的输出。如果你希望它既简短又安全,你可以写:

return Integer.compare(acc1.balance(), acc2.balance());
于 2013-05-16T08:36:24.403 回答
3

第二个更安全,因为第一个可能会为极值提供错误的结果(整数溢出)。

于 2013-05-16T08:27:11.223 回答