java排序

本文介绍了一种使用Java对List进行排序的方法,并针对原有方法进行了优化,减少了反射操作次数,提高了排序效率。

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

    public static <E> void sort(List<E> list, final String method, final String sort) {
        Comparator<E> comparator = new Comparator<E>() {

            public int compare(E a, E b) {
                int ret = 0;

                try {
                    Method m1 = (a).getClass().getMethod(method);
                    Method m2 = (b).getClass().getMethod(method);
                    Object valueB = m2.invoke(b);
                    Object valueA = m1.invoke(a);

                    Method compareTo = valueB.getClass().getMethod("compareTo", valueA.getClass());
                    if (sort != null && "desc".equals(sort)) {
                        // 倒序
                        ret = (int) compareTo.invoke(valueB, valueA);
                    } else {
                        // 正序
                        ret = (int) compareTo.invoke(valueA, valueB);
                    }
                } catch (NoSuchMethodException ne) {
                    logger.error("NoSuchMethod", ne);
                } catch (IllegalAccessException ie) {
                    logger.error("IllegalAccess", ie);
                } catch (InvocationTargetException it) {
                    logger.error("InvocationTarget", it);
                }

                return ret;
            }
        };

        Collections.sort(list, comparator);
    }

 

     通用,但三次反射损耗不少

 

     优化之后:

 

        public static <E> void sort(List<E> list, final String method, final String sort) {
        Comparator<E> comparator = new Comparator<E>() {

            public int compare(E a, E b) {
                int ret = 0;

                try {
                    Method m1 = (a).getClass().getMethod(method);
                    Method m2 = (b).getClass().getMethod(method);
                    Object valueB = (Object)m2.invoke(b);
                    Object valueA = (Object)m1.invoke(a);

                    if (sort != null && "desc".equals(sort)) {
                        // 倒序
                        ret = (int) ((Comparable<Object>) valueB).compareTo(valueA);
                    } else {
                        // 正序
                        ret = (int) ((Comparable<Object>) valueA).compareTo(valueB);
                    }
                } catch (NoSuchMethodException ne) {
                    logger.error("NoSuchMethod", ne);
                } catch (IllegalAccessException ie) {
                    logger.error("IllegalAccess", ie);
                } catch (InvocationTargetException it) {
                    logger.error("InvocationTarget", it);
                }

                return ret;
            }
        };

        Collections.sort(list, comparator);
    }

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值