处理问题对于某个对象list进行排序

  1. 重写对象的 Comparable<xxx>
对象  Item implements Comparable<Item>

/**
 * 基于4.24需求
	由于对应字段是数字的string类型,所以转换成BigDecimal 类型进行比较
 * @param o
 * @return
 */
@Override
public int compareTo(Item o) {
    Integer i = new BigDecimal(this.getTotalShare()).compareTo(new BigDecimal(o.getTotalShare()));
    /**
     * i等于0的时候表示相等;
     * i等于1的时候表示大于;
     * i等于-1的时候表示小于;
     */
    return i;
}

 

  1. 对于对象数据进行重排序
public List<Item> sortingItem(List<Item> itemsSort) {
    if (ObjectUtils.isEmpty(itemsSort)) {
        return Collections.EMPTY_LIST;
    }
    List<Item> result_mayi = new ArrayList<>();
    List<Item> result_normal = new ArrayList<>();
    List<Item> result = new ArrayList<>();
       //重用旧的排序方法,通过设置系统属性
    System.setProperty("java.util.Arrays.useLegacyMergeSort", "true");
    Collections.sort(result_mayi);
    Collections.reverse(result_mayi);
    Collections.sort(result_normal);
    Collections.reverse(result_normal);
    result.addAll(result_mayi);
    result.addAll(result_normal);
    return result;
}

System.setProperty("java.util.Arrays.useLegacyMergeSort", "true"); 是因为对应jdk7

这里用到了Collections.EMPTY_LIST  

cyMergeSort", "true");

参考网址 https://blog.csdn.net/yaomingyang/article/details/80769745

 

https://blog.csdn.net/iteye_20215/article/details/82672137

 

https://blog.csdn.net/qq_39366175/article/details/79449178

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值