显然,原子操作确保不同的线程不会破坏一个值。但是,当使用共享内存时,跨进程是否仍然如此?即使这些进程碰巧被操作系统安排在不同的内核上运行?还是跨不同的不同 CPU?
编辑:另外,如果它不安全,即使在像 Linux 这样的操作系统上也不安全,从调度程序的角度来看,进程和线程是相同的?
显然,原子操作确保不同的线程不会破坏一个值。但是,当使用共享内存时,跨进程是否仍然如此?即使这些进程碰巧被操作系统安排在不同的内核上运行?还是跨不同的不同 CPU?
编辑:另外,如果它不安全,即使在像 Linux 这样的操作系统上也不安全,从调度程序的角度来看,进程和线程是相同的?
tl;dr:阅读原子操作文档中的细则。有些设计是原子的,但可能会跳过某些变量类型。但是,一般来说,原子操作将在不同进程之间保持其契约,就像它在线程之间所做的一样。
如果两个实体同时调用,原子操作实际上只能确保您不会出现不一致的状态。例如,由两个不同线程或进程在同一个整数上调用的原子增量将始终表现如下:
其中 A 和 B 表示进行调用的第一个和第二个线程或进程。
由于竞争条件、对地址空间的不完整写入等,非原子操作可能会导致不一致或通常疯狂的结果。例如,您可以很容易地看到:
请注意竞争条件,因为实体 B 越过 A 并首先完成表达式。
现在想象一下,如果 x 是一个 64 位双精度数,则不能保证具有原子分配。在这种情况下,您可以很容易地看到如下内容:
这些非原子分配是您必须诊断的一些最可怕的并发错误。