第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

java中l(wèi)exographic字符串比較背后的邏輯是什么?

java中l(wèi)exographic字符串比較背后的邏輯是什么?

慕神8447489 2023-05-24 16:16:58
我正在實現(xiàn)一個簡單的比較器,以在 Java 中按名稱(按字母順序)對 TreeSet 中的對象進行排序。結(jié)果與我的預期不同,我很難理解 java 的 String compareTo() 方法背后的邏輯。我的期望是字符串將按字母順序排列。這是代碼清單:學生班enum Grade{ A, B, C; }class Student {    private int studentId;    private String studentName;    private int rollNumber;    private double totalMarks;    private Grade grade;    public Student(int studentId, String studentName)    {        this.studentId=this.rollNumber=studentId;        this.studentName=studentName;    }    public Student(String studentName, int rollNumber)    {        this.studentId=this.rollNumber=rollNumber;        this.studentName=studentName;    }    public int getStudentId() {        return studentId;    }    public String getStudentName() {        return studentName;    }    /**     * @return the rollNumber     */    public int getRollNumber() {        return rollNumber;    }    /**     * @param rollNumber the rollNumber to set     */    public void setRollNumber(int rollNumber) {        this.rollNumber = rollNumber;    }        /**     * @return the totalMarks     */    public double getTotalMarks() {        return totalMarks;    }    /**     * @param totalMarks the totalMarks to set     */    public void setTotalMarks(double totalMarks) {        this.totalMarks = totalMarks;        calculateGrade();    }    public void calculateGrade() {        if(this.totalMarks >= 60) this.grade = Grade.A;        else if(this.totalMarks > 40 && this.totalMarks < 60) this.grade = Grade.B;        else this.grade = Grade.C;    }    private Grade getGrade() {        return grade;    }    @Override    public String toString() {        return String.format("{name: %s, rollNumber: %d, totalMarks: %f, Grade: %s}",                 studentName,                 this.rollNumber,                this.totalMarks,                this.getGrade());    }
查看完整描述

2 回答

?
長風秋雁

TA貢獻1757條經(jīng)驗 獲得超7個贊

這里有幾個問題需要解決:

  • 您的比較運算符不正確 - 它不是比較名稱

  • 你的comparator必須和equals一致才能實現(xiàn)set操作(詳見文檔TreeSet

我建議您使用Comparator靜態(tài)方法來構(gòu)建您的比較而不是實現(xiàn)您自己的compareTo. 它更安全,更清晰:

Comparator<Student> nameOrder = Comparator.comparing(Student::getStudentName);

Set<Student> students = new TreeSet<>(nameOrder.reverse());


查看完整回答
反對 回復 2023-05-24
?
ITMISS

TA貢獻1871條經(jīng)驗 獲得超8個贊

我比較了 o1 和 o2 上的 getName() 方法,更正了排序。比較類應該是:


class StudentNameComparator implements Comparator<Student> {


? ? @Override

? ? public int compare(Student o1, Student o2) {

? ? ? ? return o1.getStudentName().compareTo(o2.getStudentName())*-1; //reverse ordering

? ? }


}


查看完整回答
反對 回復 2023-05-24
  • 2 回答
  • 0 關(guān)注
  • 181 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號