A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© a283398689 中级黑马   /  2013-10-1 17:38  /  1913 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

老师留下的作业是从控制台接受学生参数,格式如下
zhangsan,50,50,50
接受多名学生参数.并且按总分数排序,最高分排在前.写入一个文件夹中~,
详细代码如下,~用到呢omparable接口~ 这个接口我还不是太懂;

public class Student implements Comparable<Student> {
private String name;
   int ma,cn,en;
   int sum;

   public Student(String name, int ma, int cn, int en ) {
  
  this.name = name;
  this.ma = ma;
  this.cn = cn;
  this.en = en;
  this.sum = ma+cn+en;
}


public String getName(){
  return name;
}
   
   
   public int getSum (){
    return sum;
   }
   
   
   public int hashCode(){
    return name.hashCode()+sum*78;
   }
   
   
   public boolean equals (Object obj){
    if(!(obj instanceof Student)){
     throw  new ClassCastException("类型不匹配");
    }
    Student s = (Student)obj;
    return this.name.equals(s.name)&&this.sum==s.sum;
   
   
   }
   
   
@Override
public int compareTo(Student o) {
  
  int num = new Integer(this.sum).compareTo(new Integer(o.sum));
  if(num==0)
   return this.name.compareTo(o.name);
  return num;
  
}


public String toString (){
  return "student["+ name+","+ma+","+cn+","+en+"]";
}
}



这个类实现这个接口有什么用啊?

而且他怎么自己可以比较就按分高的  排序呢 谁给我讲下个接口呢~ Comparable

评分

参与人数 1技术分 +1 收起 理由
吴光新 + 1 神马都是浮云

查看全部评分

4 个回复

倒序浏览
这是通过复写comparable接口下的 compareTo()方法实现排序的;根据返回值类型是正整数,负整数,零,确定元素位置

评分

参与人数 1技术分 +1 收起 理由
吴光新 + 1 赞一个!

查看全部评分

回复 使用道具 举报
你可以查下java中这个接口的源文件,src文件夹下面直接就可以找到。因为我们再说也是和翻译它里面的内容差不多,而且里面很详细清楚哦,呵呵,祝顺。

评分

参与人数 1技术分 +1 收起 理由
吴光新 + 1 赞一个!

查看全部评分

回复 使用道具 举报
lizhangzhi 发表于 2013-10-1 18:55
这是通过复写comparable接口下的 compareTo()方法实现排序的;根据返回值类型是正整数,负整数,零,确定 ...

他是一次比较一个对象 还是一次比较所有对象呢?
回复 使用道具 举报
实现Comparable
comparable:中的方法Comparable<T >T:对于初学者可以理解为object的类型
接口中的方法:compareTo(T o)
                  比较此对象与指定对象的顺序。如果该对象小于、等于或大于指定对象,则分别返
                回负整数、零或正整数。
@Override
public int compareTo(Student o) {
  int num = new Integer(this.sum).compareTo(new Integer(o.sum));
  if(num==0)
   return this.name.compareTo(o.name);
  return num;
}
这段代码就是重写了comparable中的方法使student对象具有了比较性所以输出的代码可以显示出
按照一定的顺序进行排序。
另外你可以看看看Comparator<T>这个接口。和comparable进行比较你会收获很多
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马