首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >CompareTo法

CompareTo法
EN

Stack Overflow用户
提问于 2018-12-17 18:03:22
回答 3查看 94关注 0票数 0

最后,我认为我找到了一种使用if语句对事务进行排序的方法,但是我需要一种方法来指示一个事务比另一个事务少或大,它们交换位置。

我有到目前为止所做的事情的样本,但不太确定我在这里遗漏了什么。

代码语言:javascript
复制
    @Override
public int compareTo(Student_Transaction Tra)
{    
    if (getAmount() == ((Student_Transaction) Tra).getAmount()) {
        return Amount - Tra.getAmount();
    }
    else if (getAmount() > ((Student_Transaction) Tra).getAmount()) { 
        return 1;
    }
    else if (getAmount() < ((Student_Transaction) Tra).getAmount()) {
        return -1;
    }
    return Amount;
}
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-12-17 18:07:55

我建议你跟:

代码语言:javascript
复制
return Double.compare(this.amount, tra.getAmount());

这意味着,您可以避免执行所有这些if/else if条件。

票数 0
EN

Stack Overflow用户

发布于 2018-12-17 18:08:55

这是compareToStudent_Stransaction方法,所以不需要使用getter:

代码语言:javascript
复制
@Override
public int compareTo(Student_Transaction Tra) {
    return Tra != null ? Float.compare(amount, Tra.amount)) : 1;
}
票数 1
EN

Stack Overflow用户

发布于 2019-01-15 18:31:36

我真的意识到,我在上面的线程中所做的就是对我的问题的答案,它清楚地定义了我将如何在每个事务对象中对我的金额进行排序--这个阶段的最后一部分是使用collection.sort方法,而在最近的一个线程中,我已经发布了它是如何完成的答案。

代码语言:javascript
复制
@Override
public int compareTo(Student_Transaction Tra){
    if (Tra.getAmount() < getAmount()) { 
        return -1; 
    }
    else if (Tra.getAmount() == getAmount()) { 
        return 0;
    }
    else {
        return 1; // Tra.getAmount() > getAmount()
    }
}

我不需要做额外的事情,你的孩子只是对他的编程被误解了,我非常感谢这个专业程序员社区把他们的时间用于帮助像我这样的人:)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53820783

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档