1.hashcode 主要是为提高hash容器的效率,这是一种根据对象内存地址来决定一段整数编码
2.俩个引用如果指向同一对象,那么hash肯定会值一样
3.俩个引用如果指向不同对象,择hash值不一样
4.hash值是根据地址来计算,但是不能等价内存就是hash值
事实上有object类定义的hashcode 方法确实会针对不同对象返回不同整数,这是一般将内部地址转换(c++底层才能获取,因为java本身是在jvm上运行的)为整数
5.hashcode往往在集合中重写。
code在youku pack1 下
tt t1=new tt();
tt t2=new tt();
System.out.println("t1.hashcode=="+t1.hashCode());//判断hashcode数值确实因为地址不同而不同
System.out.println("t2.hashcode=="+t2.hashCode());
tt t3=t2;
System.out.println("t3.hashcode=="+t3.hashCode());//判断hashcode数值确实因为地址同而同
object中的tostring·方法会默认返回全类名*(包名+类名)+@+hash 值的16*进制,子类往往重写tostring ,用于返回对象的属性信息
code 看 toString
当直接输出对象时,默认输出的就是toString
测试代码:
public static void main(String[] args) {
monster m1=new monster(1900,"老虎怪","杂兵");
System.out.println(m1.toString());
System.out.println("进行对比=======================");
System.out.println(m1.hashCode());
System.out.println("================当直接输出对象时,默认输出的就是toString======================");
System.out.println(m1);
}
}
class monster{
private int attack;
private String name;
private String situation="小兵";
public monster(int attack, String name,String situation){
this.attack=attack;
this.situation=situation;
this.name=name;
}
//@Override 重写的目的就是讲类的基本·类型输出来
// public String toString() {
// return "monster{" +
// "attack=" + attack +
// ", name='" + name + '\'' +
// ", situation='" + situation + '\'' +
// '}';
// }