侧边栏壁纸
  • 累计撰写 132 篇文章
  • 累计创建 82 个标签
  • 累计收到 166 条评论

目 录CONTENT

文章目录

Java中List排序简单实现

Polar.
2017-11-06 / 0 评论 / 0 点赞 / 330 阅读 / 1,376 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2021-06-06,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

Java中List排序简单实现

在实际项目中可能会遇到不相关的表查询结果拼装成一个并按时间倒序排序,然而这样的需求往往用sql不能方便的实现,就需要分别查询出来用List返回,但是返回时需要排序。这时就需要用到Listsort

通过实现Collections.sort的compare接口实现,可排序数字、时间,顺序、倒序

/**
* List倒序排序,add_time
* @param list
*/
public static void listMapSortByAddTime(List<Map> list) {
    Collections.sort(list, new Comparator<Map>() {
        @Override
        public int compare(Map o1, Map o2) {
            SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
            try {
                Date dt1 = format.parse(o1.get("add_time")+"");
                Date dt2 = format.parse(o2.get("add_time")+"");
                if (dt1.getTime() > dt2.getTime()) {
                    return -1;
                } else if (dt1.getTime() < dt2.getTime()) {
                    return 1;
                } else {
                    return 0;
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
            return 0;
        }
    });
}

在需要排序的地方调用

Util.listMapSortByAddTime(lists);

排序前

QQ截图20171106202241.png

排序后
QQ截图20171106202318.png

如果排序的是对象,则把传入参数Map改成对象,List<Map> list
如果要排序其他类型,则把if (dt1.getTime() > dt2.getTime())判断改下即可
如果要顺序排列,则return -1改成return 1return 1改成return -1

0
广告 广告

评论区