qq_36138652
java-zh
采纳率44.4%
2019-09-04 10:29

Collections.sort()怎么样进行自定义排序呢

已采纳

对List进行Collections.sort()自定义排序遇到了一些问题。
自定义排序规则:0放在最后面,签名的都是从小到大排序。本人的代码实现了该功能,但总感觉不是最佳的办法,求大佬指教。
private static List sortLostValueList( List listLost ){

    List<Integer> playCode = new ArrayList<>();
    for(int i =0;i<listLost.size();i++){
        playCode.add( Integer.valueOf( listLost.get(i).getPlayCode() ));
    }
    System.out.println("排序之前"+JacksonUtil.java2json(playCode));
    Collections.sort(playCode,new Comparator<Integer>() {
        @Override
        public int compare(Integer o1, Integer o2) {
            if( o1 == 0 ){
                return 0;
            }
            return -1;
        }

    });
    System.out.println("第一遍排序"+JacksonUtil.java2json(playCode));
    Collections.sort(playCode,new Comparator<Integer>() {
        @Override
        public int compare(Integer o1, Integer o2) {    
            if( o1 == 0 ){
                return 0;
            }

            return o1-o2;
        }

    });

    System.out.println("第二遍排序:"+JacksonUtil.java2json(playCode));

    //把所有有关0的都放在最后面         


    return listLost;
}

图片说明

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

2条回答

  • tiankongzhichenglyf tkzc_shark 2年前

    使用lamda表达式简化

        public static void main(String[] args) {
            List<Integer> playCode = new ArrayList<>(Arrays.asList(9310, 9311, 9320, 9318, 0, 9340, 0, -1));
            System.out.println("排序之前:" + Arrays.toString(playCode.toArray()));
            playCode.sort((o1, o2) -> {
                if (o1 == 0) {
                    return 1;
                }
                if (o2 == 0) {
                    return -1;
                }
                return o1 - o2;
            });
            System.out.println("排序之后:" + Arrays.toString(playCode.toArray()));
        }
    
    点赞 1 评论 复制链接分享
  • wojiushiwo945you 毕小宝 2年前

    使用 Collections.sort 方法是需要提供一个 Comparator 的实现类的,看输出结果是升序排列的,如果想降序可以返回 o2-o1。
    排序也就是这两种方式。

    点赞 1 评论 复制链接分享

相关推荐