1. 值类型是存储在内存中的栈,而引用类型的变量在栈中仅仅是存储引用类型变量的地址来自堆,而其本身则存储在栈中。

2. ==操作比较的是两个变量的值是否相等,

3. 对于引用型变量表示的是两个变量在堆中存储的地址是否相同,即栈中的内容是否相同。


Object:

  1-----public native int hashCode();

    该方法返回的值一般是通过将该对象的内部地址转换成一个整数来实现的。

    这样能保证每个对象的哈希码值不一样。

    native:方法修饰符 ——(标志外部已实现)

    Native方法是由另外一种语言(如c/c++,汇编)实现的本地方法。

    因为在外部实现了方法,所以在java代码中,就不需要声明了,有点类似于借口方法。

    Native可以和其他一些修饰符连用,

    但是abstract方法和Interface方法不能用native来修饰,

  

  2-----public boolean equals(Object obj) {
      return (this == obj);
       }

    很明显是对两个对象的地址值进行的比较(即比较引用是否相同)。


  由于String 、Math、还有Integer、Double。。。。

  等这些封装类在使用equals()方法时,已经覆盖了object类的equals()方法。


  Integer 和 String中的。hashCode()、equals();

Integer:

  public boolean equals(Object obj) {
   if (obj instanceof Integer) {
   return value == ((Integer)obj).intValue();
   }
   return false;
} public int hashCode() {
return value;
} String: public int hashCode() {
int h = hash;
if (h == 0) {
//这就是为什么在集合set在保证一般元素无异性 比较hashcode时会很高效的原因的来源
int off = offset;
char val[] = value;
int len = count; for (int i = 0; i < len; i++) {
h = 31*h + val[off++];
}
hash = h;
}
return h;
} public boolean equals(Object anObject) {
   if (this == anObject) {
return true;
   }
   if (anObject instanceof String) {
   String anotherString = (String)anObject;
   int n = count;
   if (n == anotherString.count) {
   char v1[] = value;
   char v2[] = anotherString.value;
   int i = offset;
   int j = anotherString.offset;
   while (n-- != 0) {
   if (v1[i++] != v2[j++])
   return false;
   }
   return true;
   }
   }
   return false;
}

示例:

public class HashCodeAndEquals {
public static void main(String args[])
{
test1();
test2();
test3();
}
public static void test1()
{
Integer a1 = new Integer(182);
Integer a2 = new Integer(182);
System.out.println(a1 == a2);
   // false
System.out.println(a1.equals(a2));
     // true
System.out.println(a1.hashCode() == a2.hashCode()) ;
   // true
System.out.println();
}
public static void test2()
{
Integer a1 = new Integer(182);
String s2 = new String("182");
System.out.println(a1.equals(s2));
//if (anObject instanceof String) 直接 return false,
// instanceof 表示是否是该类的一个示例,
System.out.println();
}
public static void test3()
{
String s1 = new String("182");
String s2 = new String("182");
System.out.println(s1 == s2);
// 栈值比较 false
System.out.println(s1.equals(s2));
// true
System.out.println(s1.hashCode() == s2.hashCode()) ;
// 因为覆写了hashcode,实体内同容 true
T t1 = new T();
T t2 = new T();
System.out.println(t1.hashCode() == t2.hashCode()) ;
   // 地址映射比较 false
} } class T{
}

总结:

  由上面我们可以知道

  • 自定义类如无重写equals方法,equals和==是等价的。
  • 如果没有重写hashCode() 则是对引用型数据内存地址的一个映射的比较,肯定不同
  • Integer的 hashCode和equals则都是比较 值:
  • String的equals则是比较实体是否相同,而hashCode则是一个 value[] 值的哈希值
  • (String实例极小极小可能会出现hashCode值相同,但equals不同)
    (但是,equals相同时,hashCode一定相同)

  

java中 hashCode() 和 equals()的更多相关文章

  1. java 中hashcode和equals 总结

    一.概述            在Java中hashCode的实现总是伴随着equals,他们是紧密配合的,你要是自己设计了其中一个,就要设计另外一个.当然在多数情况下,这两个方法是不用我们考虑的,直 ...

  2. java中hashcode()和equals()的详解

    今天下午研究了半天hashcode()和equals()方法,终于有了一点点的明白,写下来与大家分享(zhaoxudong 2008.10.23晚21.36). 1. 首先equals()和hashc ...

  3. Java中hashcode,equals和==

    hashcode方法返回该对象的哈希码值. hashCode()方法可以用来来提高Map里面的搜索效率的,Map会根据不同的hashCode()来放在不同的位置,Map在搜索一个对象的时候先通过has ...

  4. java中hashcode和equals的区别和联系

    HashSet和HashMap一直都是JDK中最常用的两个类,HashSet要求不能存储相同的对象,HashMap要求不能存储相同的键. 那么Java运行时环境是如何判断HashSet中相同对象.Ha ...

  5. java中hashCode()与equals()详解

    首先之所以会将hashCode()与equals()放到一起是因为它们具备一个相同的作用:用来比较某个东西.其中hashCode()主要是用在hash表中提高 查找效率,而equals()则相对而言使 ...

  6. 深入探究Java中hashCode()和equals()的关系

    目录 一.基础:hashCode() 和 equals() 简介 equals() hashCode() 二. 漫谈:初识 hashCode() 与 equals() 之间的关系 三. 解密:深入理解 ...

  7. Java中HashCode()和equals()的作用

    引言 我们知道Java中的集合(Collection)大致可以分为两类,一类是List,再有一类是Set. 前者集合内的元素是有序的,元素可以重复:后者元素无序,但元素不可重复. 这里就引出一个问题: ...

  8. Java中hashCode、equals、==的区别

    ref:http://www.cnblogs.com/skywang12345/p/3324958.html 1.==作用: java中的==用来判断两个对象的地址是否相等:当对象是基本数据类型时,可 ...

  9. java中hashCode和equals什么关系,hashCode到底怎么用的

    Object类的hashCode的用法:(新手一定要忽略本节,否则会很惨) 马 克-to-win:hashCode方法主要是Sun编写的一些数据结构比如Hashtable的hash算法中用到.因为ha ...

随机推荐

  1. 【前端学习笔记】2015-09-09~~~~nodejs中的require()和module.exports

    nodejs中一个js文件就可以看做是一个模块 在node环境中,可以直接var a=require('模块路径以及不带扩展名的模块名') exports---module.exports 其中nod ...

  2. 剑指Offer 二进制中一的个数

    链接:https://www.nowcoder.com/questionTerminal/8ee967e43c2c4ec193b040ea7fbb10b8 来源:牛客网 public class So ...

  3. redis批量设置过期时间

    Redis 中有删除单个 Key 的指令 DEL,但好像没有批量删除 Key 的指令,不过我们可以借助 Linux 的 xargs 指令来完成这个动作.代码如下: redis-cli keys &qu ...

  4. 如何用DW设计界面 结合 VS设计后台代码

    原文发布时间为:2008-11-02 -- 来源于本人的百度文章 [由搬家工具导入] 问:在vs.net里有form标记,而dw里却没有,两个里面的标记代码都不一样,怎么能通用? 在.net里修改dw ...

  5. U3D层的运用

    在操作 LayerMask 时常令一些初学者摸不着头脑下面简单说一下层的开关方法:1.首先引入'|'.'&'.'~'的概念与(交集):10000001 & 10000100 == 10 ...

  6. inline关键词的使用(转载)

    (一)inline函数(摘自C++ Primer的第三版) 在函数声明或定义中函数返回类型前加上关键字inline即把min()指定为内联. inline int min(int first, int ...

  7. CTSC2017游记&心得记

    先来占个坑,骗点访问量 相册地址,戳这里 Day-1 一大清早就被叫了起来,赶去回车站....结果到了那里发现早了快1h?exm?是谁一早清早扰人清梦QAQ 杭州东转车,看到5号检票口被乘警团团围了起 ...

  8. GeoServer自动发布地图服务

    1 NetCDF气象文件自动发布案例 GeoServer是一个地理服务器,提供了管理页面进行服务发布,样式,切片,图层预览等一系列操作,但是手动进行页面配置有时并不满足业务需求,所以GeoServer ...

  9. indy9在程序关闭时出现terminate thread timeout的BUG解决办法

    indy9在程序关闭时出现terminate thread timeout的BUG解决办法 INDY9线程有BUG,在退出程序的时候会报错:terminate thread timeout(终止线程超 ...

  10. 四个很好的开源app项目

    Open Source and the iOS App Store Today, we are open-sourcing 4 iOS apps: ThatInbox, an email client ...