java 时间排序

本文介绍了一种使用Java自定义Comparator接口实现订单按时间降序排列的方法。通过将订单的字符串时间转换为Date类型并比较,确保最新的订单显示在列表顶部。此方法适用于需要对历史交易记录进行时间排序的应用场景。

排序使用的是

Collections.sort(List,Comparator)

自定义类实现Comparator接口

假如A的值大于B,你返回1。这样调用Collections.sort()方法就是升序

假如A的值大于B,你返回-1。这样调用Collections.sort()方法就是降序

import com.lanhetech.api.iso8583msg.utils.MyLog;
import com.lanhetech.model.user.Trade;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Comparator;
import java.util.Date;

/**
 * 订单按时间排序,最近的日期显示在上面
 */
public class ComparatorDate implements Comparator {
    public static final String TAG = "ComparatorDate";


    SimpleDateFormat format = new SimpleDateFormat("yyyy/M/d H:mm:ss");

    public int compare(Object obj1, Object obj2) {
        Trade t1 = (Trade) obj1;
        Trade t2 = (Trade) obj2;
     //   return t1.getTradetime().compareTo(t2.getTradetime());  // 时间格式不好,不然可以直接这样比较
        Date d1, d2;
        try {
            d1 = format.parse(t1.getTradetime());
            d2 = format.parse(t2.getTradetime());
        } catch (ParseException e) {
            // 解析出错,则不进行排序
            MyLog.e(TAG, "ComparatorDate--compare--SimpleDateFormat.parse--error");
            return 0;
        }
        if (d1.before(d2)) {
            return 1;
        } else {
            return -1;
        }
    }
}

使用:

 ComparatorDate c = new ComparatorDate();
 Collections.sort(notRechargeTrades, c);  // 订单按时间排序
 Collections.sort(isFinishTrades, c);
 private List<Trade> notRechargeTrades = new ArrayList<>();
 private List<Trade> backMoneyTrades = new ArrayList<>();
 private List<Trade> isFinishTrades = new ArrayList<>();
public class Trade extends ComUser implements Serializable {
    ....
    private String tradetime;        // 充值时间
    ....
Java中,编写比较方法时需要遵守“通用契约”,这是为了保证排序算法的正确性。然而,有时候会出现“java时间排序comparison method violate lts general contract”的错误。这是因为在比较方法中违反了通用契约的规定。 通用契约中指定了三个规则: 1. 反对称性(Antisymmetry):如果两个对象进行比较,其中一个大于另一个,那么另一个一定小于前者。如果两个对象相等,它们之间的比较结果应为0。 2. 传递性(Transitivity):如果对象A大于对象B,B大于对象C,那么A一定大于C。同样地,如果A等于B,B等于C,那么A一定等于C。 3. 一致性(Consistency):在比较过程中,如果两个对象发生变化,它们之间的比较结果应该随之改变。 当我们在比较Java中的时间时,经常使用的是Date类。要满足通用契约,我们需要按照时间顺序进行比较。然而,有时候我们在编写比较方法时可能没有正确地实现这些规则,导致了“java时间排序comparison method violate lts general contract”错误。 要解决这个问题,我们需要回顾一下比较方法的实现,并确保满足通用契约的规定。首先,我们应该确保在比较中使用的属性是可比较的,并且没有为null的情况。然后,我们应该检查比较方法是否正确地比较了两个对象的时间顺序,并根据比较结果返回正确的值。 此外,还有一种可能导致此错误的情况是,排序算法中使用了不支持通用契约的比较方法。在这种情况下,我们应该更改排序算法或者使用其他可靠的比较方法。 总之,解决“java时间排序comparison method violate lts general contract”错误,首先我们需要检查并修复比较方法中的错误。确保按照通用契约的规定进行比较,并且没有使用不支持通用契约的比较方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值