Java list中实体类的按照某个字段大小排序

Java list中实体类的按照某个字段大小排序

在Java中,可以使用Collections.sort()方法结合自定义的比较器来对List中的实体类按照某个字段进行排序。以下是一个示例代码,演示了如何根据实体类中的age字段对List进行排序:
go 复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
 
class Person {
    String name;
    int age;
 
    Person(String name, int age) {
        this.name = name;
        this.age = age;
    }
 
    // getters and setters
    public String getName() {
        return name;
    }
 
    public int getAge() {
        return age;
    }
}
 
public class SortExample {
    public static void main(String[] args) {
        List<Person> people = new ArrayList<>();
        people.add(new Person("Alice", 30));
        people.add(new Person("Bob", 25));
        people.add(new Person("Charlie", 35));
 
        // 根据年龄排序
        Collections.sort(people, new Comparator<Person>() {
            @Override
            public int compare(Person o1, Person o2) {
                return Integer.compare(o1.getAge(), o2.getAge());
            }
        });
 
        // 打印排序结果
        for (Person p : people) {
            System.out.println(p.getName() + ": " + p.getAge());
        }
    }
}

在这个例子中,我们定义了一个Person类,并创建了一个包含三个Person对象的List。使用Collections.sort()方法和一个匿名内部类来实现Comparator接口,以便根据age字段对List进行排序。结果将按年龄升序排列。如果你需要按降序排序,可以使用Integer.compare(o2.getAge(), o1.getAge())。

例子

go 复制代码
  @GetMapping("/selectJobNumByMoth")
    @Anonymous
    public AjaxResult selectJobNumByMoth(){
        //ArrayList<PlatMonthNumDto> list = new ArrayList<>();
        //后台查出来的月份数据
        List<PlatMonthNumDto> platMonthNumDtos = platEmploymentJobService.selectJobNumByMoth();
        for (int i = 1; i < 13; i++) {
            String str = String.valueOf(i);
            //判断12个月份是否有数据,如果没有,则添加上
            boolean b1 = platMonthNumDtos.stream()
                    .map(PlatMonthNumDto::getMonth)
                    .anyMatch(a -> a.toString().contains(str));
            if (!b1){
                PlatMonthNumDto platMonthNumDtoAdd = new PlatMonthNumDto();
                platMonthNumDtoAdd.setMonth(i);
                platMonthNumDtoAdd.setDataCount(0);
                platMonthNumDtos.add(platMonthNumDtoAdd);
            }
        }
        //按照 某个字段进行排序
        Collections.sort(platMonthNumDtos, new Comparator<PlatMonthNumDto>() {
            @Override
            public int compare(PlatMonthNumDto o1, PlatMonthNumDto o2) {
                return Integer.compare(o1.getMonth(), o2.getMonth());
            }
        });
        return AjaxResult.success(platMonthNumDtos);
    }
相关推荐
爱读源码的大都督4 分钟前
挑战一下,用Java手写Transformer,先手写QKV,能成功吗?
java·后端·程序员
华仔啊5 分钟前
面试官灵魂拷问:count(1)、count(*)、count(列)到底差在哪?MySQL 性能翻车现场
java·后端
用户0332126663679 分钟前
在Word 中插入页眉页脚:实用 Java 指南
java
奔跑吧邓邓子10 分钟前
【Java实战㊱】Spring Boot邂逅Redis:缓存加速的奇妙之旅
java·spring boot·redis·缓存·实战
杨杨杨大侠12 分钟前
Atlas-Event:高性能事件处理与监控系统
java·github·eventbus
杨杨杨大侠15 分钟前
Atlas Event:解锁事件驱动的潜能
java·github·eventbus
失散1319 分钟前
分布式专题——4 大厂生产级Redis高并发分布式锁实战
java·redis·分布式·缓存·架构
MacroZheng22 分钟前
堪称一站式管理平台,同时支持Linux、MySQL、Redis、MongoDB可视化管理!
java·linux·后端
anlogic26 分钟前
Java基础 9.10
java·开发语言·算法
SimonKing27 分钟前
数据库又慢了?你需要一个像样的慢SQL报警系统
java·后端·程序员