本文将介绍如何使用Java面向对象编程实现按照name和age进行排序的需求,通过实现Comparable接口来实现对对象的排序。
- 定义PersonSortable类
首先,我们需要定义一个PersonSortable类,该类包含一个private name和一个private age属性,表示人的姓名和年龄。以下是PersonSortable类的代码:
public class PersonSortable implements Comparable<PersonSortable> {
private String name;
private int age;
public PersonSortable(String name, int age) {
this.name = name;
this.age = age;
}
public String toString() {
return name + "-" + age;
}
public int compareTo(PersonSortable other) {
int result = name.compareTo(other.getName());
if (result == 0) {
result = age - other.getAge();
}
return result;
}
}
- 在main函数中使用
在main函数中,我们可以先输入一个整数n,表示要输入n个人的姓名和年龄。然后,我们可以通过循环读入n行数据,并将每行数据构造成一个PersonSortable对象,放入数组中。接下来,我们可以通过调用Arrays.sort方法,对数组进行排序。以下是main函数的代码:
import java.util.Arrays;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
PersonSortable[] persons = new PersonSortable[n];
for (int i = 0; i < n; i++) {
String name = scanner.next();
int age = scanner.nextInt();
persons[i] = new PersonSortable(name, age);
}
Arrays.sort(persons);
for (PersonSortable person : persons) {
System.out.println(person.toString());
}
System.out.println(Arrays.toString(PersonSortable.class.getInterfaces()));
}
}
以上代码中,我们先输入了整数n,然后通过循环读入n行数据,并将每行数据构造成一个PersonSortable对象,放入persons数组中。接下来,我们使用Arrays.sort方法对persons数组进行排序。最后,我们使用System.out.println方法输出了PersonSortable所实现的所有接口。
- 总结
本文介绍了如何使用Java面向对象编程实现按照name和age进行排序的需求,通过实现Comparable接口来实现对对象的排序。通过学习本文介绍的方法,读者可以进一步掌握Java面向对象编程的基础知识,提高编程能力。