在Java中实现集合排序

使用字面量的方式创建一个集合

java 复制代码
//使用字面量的方式初始化一个List集合
        List<User> userList = Arrays.asList(
                new User("小A",5),
                new User("小鑫",18),
                new User("小昌",8),
                new User("小鑫",8));

注意:使用Arrays.asList() api方法创建出来的集合他是一个固定长度的集合,不能进行集合的添加和删除,否则会抛出 UnsupportedOperationException异常,如果你想要添加或者删除集合元素必须使用如下方式创建集合

java 复制代码
List<User> studentList = new ArrayList<>(
	Arrays.asList(new User("杨鑫"), new User("小咪"), new User("科雷"),new User("张宝"))
	);

1、实现Comparable接口,实现集合排序

1.1、实体类实现Comparable接口

java 复制代码
package com.maochang.tenancytest.domain;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;

@AllArgsConstructor
@NoArgsConstructor
@ToString
@Data
public class User  implements Comparable<User>{

    private String name;

    private Integer age;

    /**
     * 自定义比较规格
     * @param o the object to be compared.
     * @return
     */
    @Override
    public int compareTo(User o) { //参数对象和当前对象进行比较
        //进行名称比较
        int flag = this.name.compareTo(o.name);
        //代表姓名相同
        if(flag==0){
            //A-B 如果 正数 A>B   负数A<B
            flag=this.age-o.age;
        }
        //返回比较结果
        return flag;
    }
}

1.2、使用集合工具类Collections 进行排序

java 复制代码
Collections.sort(userList);

1.3、测试方法

java 复制代码
  @Test
    void test01() {

        //使用字面量的方式初始化一个List集合
        List<User> userList = Arrays.asList(
                new User("小A",5),
                new User("小鑫",18),
                new User("小昌",8),
                new User("小鑫",8));

        //集合工具类-排序
        System.out.println("排序前:" + userList);
        System.out.println("=================开始排序==================");
        Collections.sort(userList);
        System.out.println("排序后:" + userList);
    }

2、使用Comparator 比较器实现集合对象排序

java 复制代码
public class User{
  private String name;
  private Integer age;
} 
 Collections.sort(userList,
                (o1, o2) -> {
                    int flag = o1.getName().compareTo(o2.getName());
                    if(flag == 0){
                        flag = o1.getAge() - o2.getAge();
                    }
                    return flag ;
                }
        );

简写优化写法

java 复制代码
Collections.sort(userList,
                Comparator.comparing(User::getName).thenComparingInt(User::getAge)
        );

3、使用Stream进行集合对象排序

java 复制代码
public class User{
  private String name;
  private Integer age;
} 

//如果实现了Comparable 接口
List<User> collect = userList.stream().sorted().collect(Collectors.toList());

//如果没有实现 Comparable 接口
userList.stream().sorted((o1, o2) -> {
            int flag = o1.getName().compareTo(o2.getName());
            if(flag == 0){
                flag = o1.getAge() - o2.getAge();
            }
            return flag ;
        });
//没有实现的简写方式
userList.stream().sorted(Comparator.comparing(User::getName).thenComparingInt(User::getAge));        
相关推荐
蔡俊锋1 分钟前
Javar如何用RabbitMQ订单超时处理
java·python·rabbitmq·ruby
天天摸鱼的java工程师18 分钟前
Snowflake 雪花算法优缺点(Java老司机实战总结)
java·后端·面试
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 11: 寻找峰值、山脉数组的峰顶索引
java·算法·leetcode
海梨花1 小时前
【从零开始学习Redis】项目实战-黑马点评D2
java·数据库·redis·后端·缓存
共享家95271 小时前
linux-高级IO(上)
java·linux·服务器
Sammyyyyy1 小时前
2025年,Javascript后端应该用 Bun、Node.js 还是 Deno?
开发语言·javascript·node.js
橘子郡1231 小时前
观察者模式和发布订阅模式对比,Java示例
java
指针满天飞1 小时前
Collections.synchronizedList是如何将List变为线程安全的
java·数据结构·list
Java技术小馆1 小时前
重构 Controller 的 7 个黄金法则
java·后端·面试
金銀銅鐵1 小时前
[Java] 以 IntStream 为例,浅析 Stream 的实现
java·后端