Java 集合排序方法

本文介绍了两种在Java中对对象列表进行排序的方法:一种是通过自定义比较器对List对象的属性进行排序,支持升序和降序;另一种是利用JDK1.8的Stream流API,结合Comparator接口的comparing方法进行排序。这两种方式为Java开发者提供了灵活的排序解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java对象排序的两种方法

1.传入List对象的列表 排序的数组和升降序进行排序

 
 public static <T> List<T> sort(List<T> list, final String[] properties, final String[] sorts) {
        String[] methods = getMethodName(properties);
        if (methods != null && methods.length > 0) {
            for (int i = properties.length - 1; i >= 0; i--) {
                final String method = methods[i];
                String tmpSort = ASC;
                if (sorts != null && sorts.length > i && sorts[i] != null) {
                    tmpSort = sorts[i];
                }
                final String sort = tmpSort;

                list.sort(new Comparator<T>() {
                    @Override
                    public int compare(Object a, Object b) {
                        int ret = 0;
                        try {
                            Method m1a = a.getClass().getMethod(method);
                            Method m1b = b.getClass().getMethod(method);


                            Object obj1a = m1a.invoke(a);
                            Object obj1b = m1b.invoke(b);


                            if (obj1a == null && obj1b == null) {
                                return 0;
                            }

                            if (obj1a == null || obj1b == null) {
                                if (sort != null && DESC.equals(sort)) {
                                    if (obj1a == null) {
                                        ret = -1;
                                    }
                                    if (obj1b == null) {
                                        ret = 1;
                                    }
                                } else {
                                    if (obj1a == null) {
                                        ret = 1;
                                    }
                                    if (obj1b == null) {
                                        ret = -1;
                                    }
                                }
                                return ret;
                            }
                            if (obj1a instanceof Integer && obj1b instanceof Integer) {
                                ret = ((Integer) obj1a).compareTo((Integer) obj1b);
                            } else if (obj1a instanceof Double && obj1b instanceof Double) {
                                ret = ((Double) obj1a).compareTo((Double) obj1b);
                            } else if (obj1a instanceof Float && obj1b instanceof Float) {
                                ret = ((Float) obj1a).compareTo((Float) obj1b);
                            } else if (obj1a instanceof Long && obj1b instanceof Long) {
                                ret = ((Long) obj1a).compareTo((Long) obj1b);
                            } else {
                                ret = obj1a.toString().compareTo(obj1b.toString());
                            }

                            //倒序
                            if (sort != null && DESC.equals(sort)) {
                                return -ret;
                                //正序
                            } else {
                                return ret;
                            }
                        } catch (NoSuchMethodException | IllegalAccessException | InvocationTargetException e) {
                            e.printStackTrace();
                        }
                        return ret;
                    }
                });
            }
        }
        return list;
    }

2.JDK1.8后可用Stream流提供的方法进行排序,具体使用如下:

list.stream().sorted(Comparator.comparing(Entity::getId).thenComparing(Entity::getName)).collect(Collectors.toList());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值