文章推荐:
多线程程序中操作的原子性
总结:
1.一些基本的内存读写操作是本身已经被硬件提供了原子性保证,比如一个字节的读写,对齐到16位边界的字的读写,对齐到32位边界的双字的读写。
扩展还有:对齐到64位边界的四字的读写,未缓存且在32位数据总线范围之内的内存地址的访问,对单个cache line中缓存地址的未对齐的16/32/64位访问。
所以,如果可以汇编代码是一步完成的,就已经提供了原子性保证,比如x = 1;
2.一个结构体中有存在多个变量会被CPU同时读进寄存器,如果不用同一个锁,则依旧会出现读写冲突。方法是要么使用一个锁进行管理,要么是不让其同时读进寄存器。
Windows上InterlockedXXXX的API
GNU/Linux上linux kernel中atomic_32.h
GCC中的Atomic Builtins (__sync_fetch_and_add()等)
Java中的java.util.concurrent.atomic
C++0x中的atomic operation
Intel TBB中的atomic operation