1

我正在尝试为我的课程编写一个程序来对一组对象进行排序。

有谁知道我为什么会收到这个错误?下面包含的代码片段!

学生对象

/* Class for storing students */
public class Student {
  private String name;
  private int mark;

  //Constructor
  public Student(String gName, int gMark) {
    name = gName;
    mark = gMark;
  }

  //Get Mark  
    public int getMark() {
    return mark;
  }
  //Compare to
   public int compareTo(Student gStudent) {
    return this.mark - (int) gStudent.getMark();
  }

}

并将这些学生放入(学生对象的)数组标记中;

  //Create array
    Student[] marks = new Student[numberOfMarks];

    //Input for each student
    for (int cItem = 0; cItem < numberOfMarks; cItem++) {
        System.out.print("Please enter student number "+(cItem + 1)+"'s name: ");
        String cName = markScanner.nextLine();
        System.out.print("Please enter "+cName+"'s mark: ");
        int cMark = markScanner.nextInt();
        //Skip line
        markScanner.nextLine();
        marks[cItem] = new Student(cName, cMark);
    }

但是这种排序似乎不起作用

//Sorting
Arrays.sort(marks);

并产生错误:

Exception in thread "main" java.lang.ClassCastException: Student cannot be cast to java.lang.Comparable
    at java.util.Arrays.mergeSort(Arrays.java:1144)
    at java.util.Arrays.sort(Arrays.java:1079)
    at MarkAnalysis.main(MarkAnalysis.java:33)

并产生错误

4

2 回答 2

7
public class Student implements Comparable<Student> {
  ...
}
于 2010-12-14T16:39:15.257 回答
3
public class Student implements Comparable<Student> { }

此外,您的 compareTo() 方法有点不正统。通常,您需要以下内容:

     public int compareTo(Student gStudent) {
        if(this.mark > gStudent.getMark()) return 1;
        if(this.mark < gStudent.getMark()) return -1;
        return 0;
    }
于 2010-12-14T16:39:43.150 回答