ArrayList存储学生对象类型,并根据年龄来排序,如果年龄相同,再根据姓名来排序
先构造学生类
public class 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;
}
}
再构造主函数
public static void main(String[] args) {
ArrayList<Student> arrayList = new ArrayList<Student>();
//添加数据
Student s1 = new Student("zhangsan", 20);
Student s2 = new Student("lisi", 25);
Student s3 = new Student("wangwu", 22);
Student s4 = new Student("zhaoliu", 22);
Student s5 = new Student("huqi", 21);
arrayList.add(s1);
arrayList.add(s2);
arrayList.add(s3);
arrayList.add(s4);
arrayList.add(s5);
//使用匿名内部类重写方法实现自定义排序规则
Collections.sort(arrayList, new Comparator<Student>() {
@Override
public int compare(Student s1, Student s2) {
// 进行年龄的比较
int num = s1.getAge() - s2.getAge();
//如果年龄相同,再进行姓名的比较
int num2 = num == 0 ? s1.getName().compareTo(s2.getName()) : num;
return num2;
}
});
for (Student student : arrayList) {
System.out.println(student.getAge() + " " + student.getName());
}
}