集合框架-ArrayList集合存储自定义对象的排序案例

本文介绍如何使用Collections类对ArrayList中存储的自定义对象进行排序,包括自然排序和比较器排序两种方式,并提供了具体的实现代码。

(4)案例

A:ArrayList集合存储自定义对象的排序


package cn.itcast_02;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

/*
 * Collections可以针对ArrayList存储基本包装类的元素排序,存储自定义对象可不可以排序呢?
 */
public class CollectionsDemo {
	public static void main(String[] args) {
		// 创建集合对象
		List<Student> list = new ArrayList<Student>();

		// 创建学生对象
		Student s1 = new Student("林青霞", 27);
		Student s2 = new Student("风清扬", 30);
		Student s3 = new Student("刘晓曲", 28);
		Student s4 = new Student("武鑫", 29);
		Student s5 = new Student("林青霞", 27);

		// 添加元素对象
		list.add(s1);
		list.add(s2);
		list.add(s3);
		list.add(s4);
		list.add(s5);

		// 排序
		// 自然排序
		// Collections.sort(list);
		// 比较器排序
		// 如果同时有自然排序和比较器排序,以比较器排序为主
		Collections.sort(list, new Comparator<Student>() {
			@Override
			public int compare(Student s1, Student s2) {
				int num = s2.getAge() - s1.getAge();
				int num2 = num == 0 ? s1.getName().compareTo(s2.getName()): num;
				return num2;
			}
		});

		// 遍历集合
		for (Student s : list) {
			System.out.println(s.getName() + "---" + s.getAge());
		}
	}
}


package cn.itcast_02;

/**
 * @author Administrator
 * 
 */
public class Student implements Comparable<Student> {
	private String name;
	private int age;

	public Student() {
		super();
	}

	public Student(String name, int age) {
		super();
		this.name = name;
		this.age = age;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}

	@Override
	//这是自然排序
	public int compareTo(Student s) {
		int num = this.age - s.age;
		int num2 = num == 0 ? this.name.compareTo(s.name) : num;
		return num2;
	}
}



### 头歌 13-4 ArrayList 集合 排序 Java 示例代码 在 Java 中,`ArrayList` 是一个动态数组,可以存储任意类型的对象。为了对 `ArrayList` 进行排序,可以使用 `Collections.sort()` 方法或者 `List` 接口的 `sort()` 方法。以下是一个完整的示例代码,展示如何对 `ArrayList` 进行排序。 ```java import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; class GatewayAddress { private int id; private int x; private int y; public GatewayAddress(int id, int x, int y) { this.id = id; this.x = x; this.y = y; } public int getId() { return id; } public int getX() { return x; } public int getY() { return y; } @Override public String toString() { return "GatewayAddress{id=" + id + ", x=" + x + ", y=" + y + "}"; } } public class SortExample { public static void main(String[] args) { // 创建一个存储网关的网关池(ArrayList集合ArrayList<GatewayAddress> gatewayList = new ArrayList<>(); Collections.addAll(gatewayList, new GatewayAddress(1, 45, 50), new GatewayAddress(3, 25, 30), new GatewayAddress(5, 5, 10), new GatewayAddress(2, 35, 40), new GatewayAddress(4, 15, 20)); // 自定义排序规则:按照 x 坐标升序排列 Collections.sort(gatewayList, new Comparator<GatewayAddress>() { @Override public int compare(GatewayAddress o1, GatewayAddress o2) { return Integer.compare(o1.getX(), o2.getX()); } }); // 打印排序后的网关池 System.out.println("网关池(按 x 坐标升序排列):" + "\n" + gatewayList); // 使用 Lambda 表达式进行排序:按照 y 坐标降序排列 gatewayList.sort((o1, o2) -> Integer.compare(o2.getY(), o1.getY())); // 打印排序后的网关池 System.out.println("网关池(按 y 坐标降序排列):" + "\n" + gatewayList); } } ``` #### 说明 1. 上述代码展示了如何通过 `Collections.sort()` 和 `List.sort()` 方法对 `ArrayList` 进行排序。 2. 如果需要自定义排序规则,可以通过实现 `Comparator` 接口来定义比较逻辑[^4]。 3. 在现代 Java 中,推荐使用 Lambda 表达式简化代码[^4]。 ### 注意事项 - 如果 `ArrayList` 中存储的是基本数据类型(如 `Integer`、`String` 等),可以直接调用 `Collections.sort()` 进行默认的自然排序[^1]。 - 如果存储的是自定义对象,则需要提供明确的排序规则,通常通过 `Comparator` 接口实现[^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

ZHOU_VIP

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

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

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

打赏作者

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

抵扣说明:

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

余额充值