Java中的CAS (Compare and Swap) 是通過使用Unsafe
類來實現(xiàn)的。Unsafe
類是Java中的一個特殊類,提供了一些底層操作,可以繞過Java語言的限制,直接操作內(nèi)存。
CAS操作是原子性的,它包含三個參數(shù):內(nèi)存地址、舊的預期值和新的值。CAS操作的執(zhí)行過程如下:
在Java中,可以使用Atomic
類來實現(xiàn)CAS操作。Atomic
類是Java中的原子類,提供了一系列的原子操作方法,包括CAS操作。以下是一個使用AtomicInteger
類的示例:
import java.util.concurrent.atomic.AtomicInteger;
public class CASExample {
private static AtomicInteger counter = new AtomicInteger(0);
public static void main(String[] args) {
int oldValue = counter.get();
int newValue = oldValue + 1;
while (!counter.compareAndSet(oldValue, newValue)) {
oldValue = counter.get();
newValue = oldValue + 1;
}
System.out.println("Counter: " + counter.get());
}
}
在上述示例中,首先獲取counter
的當前值。然后,通過計算得到新的值。接下來,使用compareAndSet
方法進行CAS操作,如果CAS操作失敗,則重新獲取當前值,并計算新的值,然后再次嘗試CAS操作,直到CAS操作成功。
CAS操作在多線程環(huán)境中具有很重要的作用,它可以確保多個線程同時修改同一個內(nèi)存地址時不會發(fā)生沖突。