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 に答える