在研究Java7 ConcurrentHashMap的内部实现时,我注意到为了设置新段,我们使用的是不安全类,它命令编写,并使用比较和交换算法,从而支持非阻塞行为。
,我的疑问是为什么并发HashMap不使用比较和交换算法或类似的方法来保持对单个链接列表的读和写非阻塞,而不是获取段上的锁,然后写到单链列表?。
发布于 2016-09-20 18:26:25
不安全类中的方法通常是不安全的。只有在编写库的软件工程师发现由于其他限制因素才能使用它们时才会使用它们,例如可能同时访问数据的知识,或者关于在各种处理器体系结构上如何实现原语的知识。
在这种情况下,Oracle的一些工程师已经确定不安全类可以用于分段操作,但不能用于单链接列表。
https://stackoverflow.com/questions/39600944
复制相似问题