String中hashCode方法的线程安全

Posted cblogs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了String中hashCode方法的线程安全相关的知识,希望对你有一定的参考价值。

class String{
  //默认值是0
  int hash;

  public int hashCode() {
       //将成员变量hash缓存到局部变量
        int h = hash;
    //这里使用的是局部变量,没有多线程修改的风险
        if (h == 0 && value.length > 0) {
            char val[] = value;
            //求hashcode过程使用局部h变量防止产生静态条件
            for (int i = 0; i < value.length; i++) {
                h = 31 * h + val[i];
            }
            //把求出的hashcode缓存到局部变量,原子操作,这里不需要考虑线程可见性的问题,如果其它线程未能及时看到最新修改,重新计算hash值代价也不大
            hash = h;
        }
return h; } }

这里没有使用锁,但保证了线程安全,使用的是栈封闭的思想,

把对象缓存到局部变量进行修改,就不会产生静态条件,

修改完成后再以原子的方式放回缓存。


以上是关于String中hashCode方法的线程安全的主要内容,如果未能解决你的问题,请参考以下文章

代码安全 | 第十七期:对象只定义了Equals和Hashcode方法之一的漏洞

JavaEE几个线程不安全的原因和解决方法

HashMap是线程安全的吗?如何实现线程安全?

HashMap为啥不安全?

Java多线程的一些方法

String hashCode 方法为什么选择数字31作为乘子