对list集合进行排序学习笔记

对List进行排序
1.User对象:实现Comparable接口,并重写里面的compareTo(User o) {…}方法;
2.测试方法里面使用Collections.sort(userList);进行排序;
User对象

/**
 * 用户实体
 * @Date: 2019/7/23 22:12
 * @Auther: HuShiwei
 */
public class User implements Comparable<User>{

    private String name;
    private Integer age;
  
  //...get和set方法省略
   
    //全参构造器
    public User(String name, Integer age) {
        this.name = name;
        this.age = age;
    }

    //排序设置
    //PS:默认升序,compareTo前后参数反着写就是降序
    @Override
    public int compareTo(User o) {

        return this.age.compareTo(o.age);
        //return o.age.compareTo(this.age);
    }
}

测试方法:

@Test
    public void upSortFun(){
        List<User> userList = new ArrayList<>();
        userList.add(new User("王五",23));
        userList.add(new User("李四",22));
        userList.add(new User("张三",21));
        userList.add(new User("赵六",24));
        Collections.sort(userList);

        for (User user :userList){
           System.out.println(user.getName()+user.getAge());
        }
    }

输出结果:

张三21
李四22
王五23
赵六24

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很好的问题!让我来解答。 首先,让我们来了解一下 `Comparable` 接口。这个接口是 Java 中的一个接口,它只有一个方法 `compareTo()`。这个方法的作用是定义类的自然排序顺序。 如果我们要对一个对象集合进行排序,只需要让这个类实现 `Comparable` 接口,并且重写 `compareTo()` 方法。这个方法返回一个整型值,表示该对象与另一个对象的大小关系。如果该对象小于另一个对象,则返回负整数;如果两个对象相等,则返回零;如果该对象大于另一个对象,则返回正整数。 下面是一个简单的例子,展示如何使用 `Comparable` 接口进行排序。 ```java public class Student implements Comparable<Student> { private String name; private int age; public Student(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } // 重写 compareTo 方法 @Override public int compareTo(Student o) { // 按照年龄从小到大排序 return this.age - o.getAge(); } } ``` 在这个例子中,我们定义了一个 `Student` 类,并且让它实现了 `Comparable` 接口。我们重写了 `compareTo()` 方法,按照年龄从小到大排序。 现在,我们可以使用 `Collections.sort()` 方法对 `Student` 对象进行排序了: ```java List<Student> students = new ArrayList<>(); students.add(new Student("Tom", 20)); students.add(new Student("Jerry", 18)); students.add(new Student("Alice", 22)); Collections.sort(students); for (Student student : students) { System.out.println(student.getName() + " " + student.getAge()); } ``` 输出结果为: ``` Jerry 18 Tom 20 Alice 22 ``` 可以看到,我们成功地按照年龄从小到大对 `Student` 对象进行了排序。 希望这个例子能够帮助你理解如何使用 `Comparable` 接口进行排序。如果你还有其他问题,请随时提出!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值