Java String类(JDK1.8)

一、hashCode函数

public int hashCode() { int h = hash; if (h == 0 && value.length > 0) { char val[] = value; for (int i = 0; i < value.length; i++) { h = 31 * h + val[i]; } hash = h; } return h; }

  • hashCode()对字符串的哈希值是做了缓存的,第一次会创建哈希值,往后的则将使用缓存中的值。
  • 使用的计算方法为:s[0]*31(n-1)+s[1]*31(n-2)+....+s[n-1]
  • 使用31作为基数
    • 31 * i = 32 * i - i = (i<<5) - i 通过移位和减法运算,有助于提高运算速度。
    • 31是质数
  • 一个对象如果存储在散列集合内,需要复写hashCode,因为散列集合存储对象是根据hashCode的值(相当于地址)进行存储。
  • 从函数的实现可以得到一个转换成10进制的工具:

public static int calculate(int radix, int[] a) { int sum = 0; for (int i = 0; i < a.length; i++) { sum = sum * radix + a[i]; } return sum; }

二、equals函数

public boolean equals(Object anObject) { if (this == anObject) { return true; } if (anObject instanceof String) { String anotherString = (String)anObject; int n = value.length; if (n == anotherString.value.length) { char v1[] = value; char v2[] = anotherString.value; int i = 0; while (n-- != 0) { if (v1[i] != v2[i]) return false; i++; } return true; } } return false; }

  • 重写equals要遵守以下特征:
  • 自反性:对于任何非null的引用值x, x.equals(x)必须返回true。
  • 对称性:对于任何非null的引用值x和y,当且仅当y.equals(x)返回true时,x.equals(y)必须返回true
  • 传递性:对于任何非null的引用值x,y和z,如果x.equals(y)返回true,并且y.equals(z)返回true,那么x.equals(z)返回true
  • 对于任何非null的引用值x和y,只要equals的比较操作在对象中所用的信息没有被修改,多次调用x.equals(y)就会一致地返回true,或者一致地返回false
  • 对于任何非null的引用值x,x.equals(null)必须返回false
  • 运行流程:
  • 先判断是否自身对象
  • 再判断是否是String类实例(子类也算)
  • 再判断字符串长度
  • 最后判断对比每个字符
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,778评论 18 399
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,776评论 0 33
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,374评论 11 349
  • 概述 音视频采集是直播架构的第一步 音视频采集包括两部分视频采集音频采集 iOS 开发中,同音视频采集相关 API...
    哎呀我Qu阅读 3,203评论 0 4