我正在尝试按特定属性(“程序”的“学生”对象和“教师”的“教授”对象)对两个不同的对象数组列表进行排序。这两个类都扩展了我的抽象“人”类。
public abstract class Person implements Comparable<Person>{
private String name;
private String adress;
//getters, setters, etc., all works properly
@Override
protected Object clone() throws CloneNotSupportedException {
return super.clone();
}
public int compareTo(String string) {
return name.compareTo(string);
}
}
然后,当我创建一个由 1000000 个随机“人”对象组成的数组时,可以是学生或教授,我决定像这样按他们的名字按字母顺序排序(这可以正常工作)。
Person personByName[] = arrayPersonas.clone();
Arrays.sort(personByName);
然后,我将原始 Person 数组划分为两个 ArrayList,一个用于 Student 对象,另一个用于教授对象:
ArrayList<Student> studentsByProgram = new ArrayList();
ArrayList<Professor> professorsByFaculty = new ArrayList();
for (int i = 0; i < 1000000; i++) {
if (arrayPersonas[i] instanceof Student) {
studentsByProgram.add((Student)arrayPersonas[i]);
} else {
professorsByFaculty.add((Professor)arrayPersonas[i]);
}
}
当我尝试按我想要的属性按字母顺序对每个 ArrayList 进行排序时,问题就出现了,因为它一直按 Person 的名称对它们进行排序:
Collections.sort(studentsByProgram);
Collections.sort(professorsByFaculty);
在这里,我离开我的学生和教授课程:
public class Student extends Person {
private String program;
private int year;
private double fee;
//constructor, setters, getters, toString, equals
@Override
protected Object clone() throws CloneNotSupportedException {
return super.clone();
}
public int compareTo(String string) {
return program.compareTo(string);
}
@Override
public int compareTo(Person t) {
return super.compareTo(t.getName());
}
}
教授班:
public class Professor extends Person {
private String faculty;
private double salary;
//constructor, setters, getters, toString, equals
@Override
protected Object clone() throws CloneNotSupportedException {
return super.clone();
}
public int compareTo(String string) {
return faculty.compareTo(string);
}
繁花不似锦
慕田峪9158850
POPMUISE
相关分类