黑马程序员技术交流社区
标题:
一直看不懂为什么要实现Comparable呢?
[打印本页]
作者:
zhou1234
时间:
2014-12-17 21:14
标题:
一直看不懂为什么要实现Comparable呢?
为什么要覆盖hashcode? 又没有tree
import java.util.*;
class MapTestDemo
{
public static void main(String[] args)
{
Map<Student,String> student=new HashMap<Student,String>();//创建Map集合
student.put(new Student("aaa",20),"henan");
student.put(new Student("aaa",20),"henan");
student.put(new Student("aaa",20),"henan");
student.put(new Student("ccc",22),"北京");
Set<Student> set=student.keySet();//获取键的集合
Iterator<Student> it=set.iterator();//创建一个迭代器
while(it.hasNext())
{
Student p=it.next();
String value=student.get(p);
System.out.println(p.getName()+"..."+p.getAge()+"..."+value);
}
}
}
class Student implements Comparable<Student>//实现 和 覆盖两个方法 为什么要实现Comparable?
//为什么还要覆盖呢,这两个有什么区别
{
private String name;
private int age;
Student(String name,int age)
{
this.name=name;
this.age=age;
}
public int compareTo(Student s)//实现
{
int num=new Integer(this.age).compareTo(new Integer(s.age));
if(num==0)
return this.name.compareTo(s.name);
return num;
}
public String getName()
{
return name;
}
public int getAge()
{
return age;
}
public int hashCode()//覆盖
{
return name.hashCode()+age*34;
}
public boolean equals(Object obj)//覆盖
{
if(!(obj instanceof Student))
throw new ClassCastException("类型不匹配");
Student s=(Student)obj;
return this.name.equals(s.name) && this.age==s.age;
}
}
作者:
noiary
时间:
2014-12-17 21:37
其实两个方法都是覆盖,实现是class Student implement xxx 这里叫实现。
至于为什么覆盖,是Hash集合在内部排序时,会用到这两个方法,而要求覆盖是一种规范,java总要通过一种方式告诉我们该怎么做会更好,所以通过接口的方式,如果你想使用hash集合,必须实现comparable接口,这是一种规范,以后我们写一些特定的工具类时,也会这么写。
当然,这些都是个人的一点浅见,可能有说的不准确的地方,记得毕老师视频讲得挺详细的,如果不理解就再看几遍,后面张孝祥老师也有讲过hashCode的特点,是java高新技术《26ArrayList_HashSet的比较及Hashcode分析.avi》。
加油吧朋友,共勉。
作者:
zhou1234
时间:
2014-12-18 02:11
noiary 发表于 2014-12-17 21:37
其实两个方法都是覆盖,实现是class Student implement xxx 这里叫实现。
至于为什么覆盖,是Hash集合在内 ...
恩恩 谢谢你:D
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2