Java小知识:使用Lambda函数,根据一个字段对List集合进行排序(升序&倒序)

1.升序排列

public static void main(String[] args){
	//随便组装个集合
	List<SpClassConfig> spClassConfigs = new ArrayList<SpClassConfig>();
	SpClassConfig spClassConfig = new SpClassConfig();
	spClassConfig.setClassId("1");
	spClassConfig.setClassDays(50);
	spClassConfigs.add(spClassConfig);
	SpClassConfig spClassConfig2 = new SpClassConfig();
	spClassConfig2.setClassId("2");
	spClassConfig2.setClassDays(34);
	spClassConfigs.add(spClassConfig2);
	SpClassConfig spClassConfig3 = new SpClassConfig();
	spClassConfig3.setClassId("3");
	spClassConfig3.setClassDays(63);
	spClassConfigs.add(spClassConfig3);
	
	//根据classDays字段,对spClassConfigs集合进行升序排列
	spClassConfigs.sort((x, y) -> Integer.compare(x.getClassDays(), y.getClassDays()));
	
	//打印结果
	for (SpClassConfig stu : spClassConfigs) {
		System.out.println(stu.getClassDays());
	}

打印结果如下:
在这里插入图片描述

2.倒序排列

public static void main(String[] args){
	//随便组装个集合
	List<SpClassConfig> spClassConfigs = new ArrayList<SpClassConfig>();
	SpClassConfig spClassConfig = new SpClassConfig();
	spClassConfig.setClassId("1");
	spClassConfig.setClassDays(50);
	spClassConfigs.add(spClassConfig);
	SpClassConfig spClassConfig2 = new SpClassConfig();
	spClassConfig2.setClassId("2");
	spClassConfig2.setClassDays(34);
	spClassConfigs.add(spClassConfig2);
	SpClassConfig spClassConfig3 = new SpClassConfig();
	spClassConfig3.setClassId("3");
	spClassConfig3.setClassDays(63);
	spClassConfigs.add(spClassConfig3);
	
    //根据classDays字段,对spClassConfigs集合进行倒序排列
	Collections.sort(spClassConfigs, new Comparator(){
		@Override
		public int compare(Object o1, Object o2) {
			SpClassConfig stu1=(SpClassConfig)o1;
			SpClassConfig stu2=(SpClassConfig)o2;
			if(stu1.getClassDays()>stu2.getClassDays()){
				return -1;
			}else if(stu1.getClassDays()==stu2.getClassDays()){
				return 1;
			}else{
				return 0;
			}
		}
	});
	
	//打印结果
	for (SpClassConfig stu : spClassConfigs) {
		System.out.println(stu.getClassDays());
	}
}

打印结果如下:
在这里插入图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要对 Java 对象 List 根据对象的两个数字字段进行列表排序,你可以使用 Java 的 Comparator 接口。Comparator 接口是一个函数式接口,你可以使用 Lambda 表达式简化代码。 下面是一个示例代码: ```java import java.util.*; public class Example { public static void main(String[] args) { // 创建对象列表 List<MyObject> list = new ArrayList<>(); list.add(new MyObject(2, 1)); list.add(new MyObject(1, 2)); list.add(new MyObject(3, 3)); // 根据数字字段进行排序 Collections.sort(list, Comparator.comparing(MyObject::getNumber1).thenComparing(MyObject::getNumber2)); // 输出排序后的列表 System.out.println(list); } } class MyObject { private int number1; private int number2; public MyObject(int number1, int number2) { this.number1 = number1; this.number2 = number2; } public int getNumber1() { return number1; } public int getNumber2() { return number2; } @Override public String toString() { return "MyObject{" + "number1=" + number1 + ", number2=" + number2 + '}'; } } ``` 在上面的示例代码中,我们首先创建了一个对象列表 `list`。然后,我们使用 `Comparator.comparing()` 方法指定两个数字字段进行排序。`thenComparing()` 方法可以用于在第一个字段相同时,按照第二个字段进行排序。最后,我们使用 `Collections.sort()` 方法对列表进行排序。 输出结果为: ``` [MyObject{number1=1, number2=2}, MyObject{number1=2, number2=1}, MyObject{number1=3, number2=3}] ``` 可以看到,列表已经按照指定的数字字段进行排序了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值