java.util.concurrence底层依赖的基础:Unsafe的compareAndSwap**()。
其依赖于硬件的testAndSet指令。一般的指令都是read或者write,而为了同步互斥,硬件厂商专门开发了testAndSet指令。其原理是“测试一个内存地址里的值V,是否为期望的except,如果是则更新为update,否则不更新且告诉程序非”。
由于testAndSet是一个指令,因此引号内的操作不会被中断从而保证其原子性。
这种方式与synchronized方式最大的区别是,第二种方式线程不会阻塞,而是由应用程序自己决定在条件失败之后的操作(一般是不断的尝试去获得)。
synchronized可以认为是悲观锁(在保证得到锁之后才去执行),而第二种可以认为是乐观锁(它在不知道的情况下,可以不停的尝试去获得这个锁)。
PS:根据硬件不同,可能会是其他类似的指令。