8.1 原子访问:Interlocked系列函数
机器上装配cpu的数量,也会影响到多线程访问某全局变量使其自增的结果。当然操作系统会提供一系列函数来保持结果的一致性。
我们必须确保传给这些函般的变革t地址是经过对齐的,否则这些函数可能会失败。
在实现旋转锁(spinlock)的时候 , lnterlockedExchange 极其有用。
我们必须确保锁变量和锁所保护的数据位于不同的高速缓存行???
另外不知道为什么给while轮询这种好费cpu时间的方式起一个“旋转锁”的名字,还是自己对旋转锁没有理解到位?
同时提供了Interlocked 单向链表函数。
8.2 高速缓存
值得多研究下。
8.3 高级线程同步
关键段,前后两个事件内核对象描述有点问题?
volatile(直接读取物理内存)如何展示同步功能?
8.5Slim读/写锁
表 8-2 同步机制性能比较:volatile,无论 CPU 或者线程数量多少,读取时间始终不会有太大的变化??
读volatile为什么时间都是一样的?
写入一个 volatîle为什么和缓存一致性相关?
8.6 条件变量
有时我们想让线程以原于方式,把锁释放,井将自己阻塞,直到某个条件成立为止。
08-UserSyncCompare是个很好的例子,最好对于单/多处理器,单/多线程情况都拿进来分析一下。
1、同步有两个含义:
1)函数返回的机制中,有同步异步返回之分;
2)资源被线程安全地访问,需要线程同步地去访问;