我有一个运行多线程的程序,所有线程共享和处理单个 AtomicLong 变量。他们每个人都会getAndAdd()
首先调用方法来检索值并进一步处理。
如果所有线程同时运行,调用上述方法是否会导致一个线程等待另一个线程完成获取值?
我有一个运行多线程的程序,所有线程共享和处理单个 AtomicLong 变量。他们每个人都会getAndAdd()
首先调用方法来检索值并进一步处理。
如果所有线程同时运行,调用上述方法是否会导致一个线程等待另一个线程完成获取值?
线程没有等待(在 的意义上Object::wait
),它们一直在循环,直到成功获取并添加到AtomicLong
.
作为参考,JDK 8 中的代码如下所示:
public final long getAndAddLong(Object o, long offset, long delta) {
long v;
do {
v = getLongVolatile(o, offset);
} while (!compareAndSwapLong(o, offset, v, v + delta));
return v;
}
请注意,该方法可能是内在的(即它在运行时被更有效的东西替换,通常是单个 CPU 指令)