什么是原子操作
所谓原子操作,就是“不可中断的一个或一系列操作”。
原子操作的目的:保护资源。
这里的“中断”并不翻译成操作被中断停止执行,更确切地应该指在执行的整个过程中,对所用到的资源是独占的。
单核系统的原子操作
在单核CPU中,能够在一条指令(机器指令/汇编指令)中完成的操作都可以看作为原子操作。无论是设备中断请求、时间片超时、程序主动schedule放弃CPU,抑或是发生抢占,从而引起线程调度中断当前程序操作,都是发生在指令间的。计算机的每条指令的执行天生就是原子性不可中断的,这是由硬件设计决定的。
对高级程序(C/C++等)而言,一条语句对应几条指令,是由编译器、指令集(或者说硬件架构设计)决定的,即是由软件硬件共同决定。编译器决定了上层语言被翻译成什么指令,而指令决定了操作是否是原子性的。如,对CISC来说,是能够直接操作内存数据的,可以由一条指令完成,这就是原子操作;而在RICS中,数据需要先load到寄存器进行操作,再store回内存,无法在一条指令中完成,这就不是原子操作。
当指令集提供了一条指令能完成读写的操作时,该读写操作就成为原子操作。而指令依赖硬件通路,最终原子操作将由硬件保证。
多核系统的原子操作
在单核CPU中,内存的访问总是只由一个核心来进行的。当存在多个核心时,每个核心上执行的程序同时执行一条指令能完成的操作,同时对同一地址的内存进行访问,这时得到的结果可能不是预期的,此时依然不能说它们是原子操作。