关于ReferenceResource的问题#hold

protected final AtomicLong refCount = new AtomicLong(1); public synchronized boolean hold() { if (this.isAvailable()) { if (this.refCount.getAndIncrement() > 0) { return true; } else { this.refCount.getAndDecrement(); } }

    return false;
}

refCount已经是AtomicLong类型,是否有必要将hold方法放在同步块中

原提问者GitHub用户rushsky518

展开
收起
芬奇福贵 2023-05-26 13:50:57 84 分享 版权
1 条回答
写回答
取消 提交回答
  • IMO,有必要添加同步,保持方法必须与下面的同步块互斥。否则,hold可能会返回true并清除成功。

    rocketmq/store/src/main/java/org/apache/rocketmq/store/ReferenceResource.java

    Lines 56 to 65 in 73bb4b4

    public void release() { long value = this.refCount.decrementAndGet(); if (value > 0) return;

     synchronized (this) { 
    
         this.cleanupOver = this.cleanup(value); 
     } 
    

    }

    原回答者GitHub用户RongtongJin

    2023-05-26 17:42:50
    赞同 展开评论
问答地址:

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

还有其他疑问?
咨询AI助理