ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、视频、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
## 概述 任何对象,都有一个哈希值,这个哈希值是对象的一个整数数字表示. 对象的字符串表示是toString()方法. ## 如何获取对象的哈希值 每一个对象都有一个方法,hashCode(),这个方法定义在了Object类中,所以每个对象都具有. 在p中存储了真正的地址,但是在java 中看不了,可以 看toString()方法,它是把哈希值转成十六进制了 . ~~~ Person p = new Person(); System.out.println(p.hashCode()); System.out.println(p); ~~~ ``` 20671747 //将这个数值转换为十六进制,就是下面内存地址13b6d03 com.like_so.Person@13b6d03 //地址地址就是哈希值的十六进制,以前说的地址值,实际上根本不是地址值,实际上是哈希值的十六进制表示. 在java无法看真正的内存地址值 ``` ## 哈希值的由来 哈希值是由真正的地址值得来的,通过一种散列算法(哈希算法).哈希算法是不可逆的. ## String的哈希值 过源码可以知道,String重写了hashCode()方法,哈希值不再童年各国地址值计算.String类型的hashcode只跟内容有关,所以只要字符串的内容相同,hashcode的值就是一致的. 只要字符串的内容一样,哈希值肯定一样. 字符串的哈希值一样,如果两个那么内容可能不一样. ## 哈希表结构 数组结构+连表结构的组合,查询快,增删快. ## 哈希表判断元素是否重复的原理 1. 先判断新元素的哈希值和旧元素的哈希值是否相同.如果都不相同,直接判断不重复,添加. 2. 如果重复,则调用equals()进行比较,如果返回的是true,判定重复元素,不添加.如果是false,判定不重复,添加. ![](https://box.kancloud.cn/96f3c69b08949dc54e18422f973e84bc_1178x537.png) ~~~ Set<String> s = new HashSet<>(); System.out.println("通话".hashCode()); System.out.println("重地".hashCode()); //这两个的哈希值是相同的 s.add("php"); s.add("通话"); s.add("重地"); System.out.println("abc".hashCode()); System.out.println("acD".hashCode()); s.add("abc"); s.add("abc"); s.add("acD"); System.out.println(s.size()); ~~~ 结果 ``` 1179395 1179395 96354 96354 5 [通话, 重地, abc, acD, php] ``` 只有哈希值相同,equals()返回true,才判定重复.