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;
}

图片说明

使用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()));
    }

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

可以自定义一个比较器,然后对对象进行排序比较,如:http://www.java265.com/JavaJingYan/202203/16485461582619.html