What does “spurious failure” on AtomicInteger weakCompareAndSet mean?

后端 未结 4 1935
不思量自难忘°
不思量自难忘° 2021-02-05 08:43

The Java AtomicInteger class has a method -

boolean weakCompareAndSet(int expect,int update)

Its documnentation says:

Ma

4条回答
  •  面向向阳花
    2021-02-05 09:20

    spuriously: for no apparent reason

    According to atomic package javadoc:

    The atomic classes also support method weakCompareAndSet, which has limited applicability.

    On some platforms, the weak version may be more efficient than compareAndSet in the normal case, but differs in that any given invocation of the weakCompareAndSet method may return false spuriously (that is, for no apparent reason).

    A false return means only that the operation may be retried if desired, relying on the guarantee that repeated invocation when the variable holds expectedValue and no other thread is also attempting to set the variable will eventually succeed.
    (Such spurious failures may for example be due to memory contention effects that are unrelated to whether the expected and current values are equal.)

    Additionally weakCompareAndSet does not provide ordering guarantees that are usually needed for synchronization control.


    According to this thread, it is not so much because of "hardware/OS", but because of the underlying algorithm used by weakCompareAndSet :

    weakCompareAndSet atomically sets the value to the given updated value if the current value == the expected value. May fail spuriously.

    Unlike compareAndSet(), and other operations on an AtomicX, the weakCompareAndSet() operation does not create any happens-before orderings.

    Thus, just because a thread sees an update to an AtomicX caused by a weakCompareAndSet doesn't mean it is properly synchronized with operations that occurred before the weakCompareAndSet().

    You probably don't want to use this method, but instead should just use compareAndSet; as there are few cases where weakCompareAndSet is faster than compareAndSet, and there are a number of cases in which trying to optimizing your code by using weakCompareAndSet rather than compareAndSet will introduce subtle and hard to reproduce synchronization errors into your code.


    Note regarding happens-before orderings:

    The Java Memory Model (JMM) defines the conditions under which a thread reading a variable is guaranteed to see the results of a write in another thread.

    The JMM defines an ordering on the operations of a program called happens-before.

    Happens-before orderings across threads are only created by synchronizing on a common lock or accessing a common volatile variable.

    In the absence of a happens-before ordering, the Java platform has great latitude to delay or change the order in which writes in one thread become visible to reads of that same variable in another.

提交回复
热议问题