如果你把0x61c88647转换成十进制,你会得到1640531527,这是没有意义的,直到你意识到它是32位,它是2654435769的签名版本。再次这个数字似乎有点奇怪,直到你意识到它是2的32次方乘以X其中X是黄金比例(√5-1)÷2近似0.618。
现在它如何适合ThreadLocal?当您创建新的ThreadLocal时,会根据之前的ID +我们的幻数分配一个ID。它被放入ThreadLocalMap中。如果发生冲突,ThreadLocalMap会将值放入下一个可用空间。我们的神奇值允许在此散列中优化“展开”值以避免这种情况。ThreadLocalMap采用黄金分割数的方式,大大降低了哈希冲突的情况
为什么是1879881855 而不是1640531527 ?求解释