传统的排序和java8新的排序比较 (排序)

本文详细介绍Java中使用传统方法和Lambda表达式进行集合排序的具体实现方式,包括升序、降序及多条件组合排序等高级应用。

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

1:传统排序方法

/**
 * 常规升排序
 */
public static void sortTest() {
    List<User> list = new ArrayList <>(  );
   list.add( new User( "a",1 ) );
    list.add( new User( "f",6 ) );
    list.add( new User( "d",7 ) );
    list.add( new User( "f",0 ) );
    list.add( new User( "q",12 ) );


    //按照id排序
    Collections.sort( list, new Comparator <User>( ) {
        @Override
        public int compare(User o1, User o2) {
            return o1.getId() - o2.getId();
            //o2.getId() - o1.getId()  降序
            //o1.getId() - o2.getId()  升序
        }
    } );


    //按照name排序。只需要重写匿名内部类就可以
    Collections.sort( list, new Comparator <User>( ) {
        @Override
        public int compare(User o1, User o2) {
            return o1.getName().compareTo( o2.getName() );
            //o1.getName().compareTo( o2.getName() );
            //o2.getName().compareTo( o1.getName() )
        }
    } );

    //遍历结果,是否排序
    for (User u :list) {
        System.out.println(u);
    }


    /**
     * 升序  Collections.sort(list)    
     * 降序  Collections.reserve(list)   
     * 随机  Collections.shuffle(list) 
     */

}



2:Lambda排序

/**
 * Lambda排序
 *  /**
 * 升序  Collections.sort(list)
 * 降序  Collections.reserve(list)
 * 随机  Collections.shuffle(list)
 */
public static void lambdaTest() {
   List<User> list = getList();

    //排序    降序
    list.sort((o1, o2) -> o2.getId() - o1.getId());

    //排序    升序
    list.sort((o1, o2) -> o1.getId() - o2.getId());

    //遍历
    list.forEach( System.out::println);
}


/**
 * 多条件组合排序
 *  /**
 * 升序  Collections.sort(list)
 * 降序  Collections.reserve(list)
 * 随机  Collections.shuffle(list)
 */
public static void lambdaTest02() {
    List<User> list = getList();

    list.sort(Comparator
            .comparing(User::getId).reversed()
            .thenComparing(Comparator.comparing(User::getName)).reversed()
    );

    list.forEach( user ->System.out.println(user));
/** * 获取list * @return */public static List<User> getList() { List<User> list = new ArrayList <>( ); list.add( new User( "a",1 ) ); list.add( new User( "f",6 ) ); list.add( new User( "d",7 ) ); list.add( new User( "k",0 ) ); list.add( new User( "d",56 ) ); list.add( new User( "g",125 ) ); list.add( new User( "u",25 ) ); list.add( new User( "y",87 ) ); list.add( new User( "t",53)); list.add( new User( "r",123 ) ); list.add( new User( "e",987 ) ); list.add( new User( "q",4 ) ); return list;


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

托尼吴

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值