黑马程序员技术交流社区
标题: 有关io的问题 [打印本页]
作者: ↙五线谱╲ 时间: 2013-10-31 09:07
标题: 有关io的问题
老师留下的作业是从控制台接受学生参数,格式如下
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
作者: ヅ飞飞 时间: 2013-10-31 09:27
本帖最后由 ヅ飞飞 于 2013-10-31 14:20 编辑
如果需要使用TreeSet,TreeMap容器时要实现Comparable接口重写compareTo方法。
当我们创建的一个类这个类需要实例化很多对象时,要用容器来封装对象。而使用不同容器需要对该类有不同操作,如:使用HashMap,HashSet是该类要重写hashCode方法和equals方法;使用TreeSet,TreeMap是该类要实现Comparable接口重写compareTo方法。当使用容器不确定时这些操作通常会都做。
作者: 黄炳期 时间: 2013-10-31 10:53
TreeSet对元素进行排序的方式:
方式一:让元素具备比较功能。
元素需要实现comparable接口,覆盖compareTo()方法。如果不要按照对象中具备的自然顺序进行排序,如果对象中不具备自然
顺序,那么就使用方式二。
方式二:让集合自身具备比较功能。
定义一个类实现Comparator接口,覆盖compare方法,将该类对象作为参数
传递给TreeSet集合的构造函数。
实现这个接口就是要重写compareTo方法,使之实现按照num大小排序。
int num = new Integer(this.sum).compareTo(new Integer(o.sum));
如果this.sum>o.sum,num为整数。
this.sum<o.sum,num为负数。
this.sum==o.sum,num==0,这时候就需要根据name来排序。
作者: 杨增坤 时间: 2013-11-1 15:19
和 入学测试题很相似的啊
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) |
黑马程序员IT技术论坛 X3.2 |