一、atomic包与原子操作
atomic包是Go语言提供的原子操作(atomic operation)原语的相关接口。原子操作是相对于普通指令操作而言的。以一个整型变量自增的语句为例:
var i int
i++
i++这行语句需要以下3条普通机器指令来完成变量i的自增。
LOAD:将变量从内存加载到CPU寄存器。
ADD:执行加法指令。
STORE:将结果存储回原内存地址。
这3条普通指令在执行过程中是可中断的。而原子操作的指令是不可中断的,它就好比一个事务,要么不执行,一旦执行就一次性全部执行完毕,不可分割。
正因如此,原子操作可用于共享数据的并发同步。