最近看了下windows核心编程,虽然是比较老的书,但是感觉还是蛮有用的,顺便复习了一些操作系统的知识,比如本文的进程同步机制
用户模式下的线程同步
线程之间需要通信:
1.需要让多个线程同时访问一个共享资源,同时不能破坏资源的完整性
2.一个线程需要通知其他线程某项任务已经完成
方法一:原子访问:Interlocked系列函数
InterlockedExchangeAdd(long & ,int );
InterlockedIncrement;
InterlockedExchange;(实现旋转锁是有用)
必须保证传给这些函数的变量地址是对齐的,否则函数可能失败
interlockde函数不需要在内核模式与用户模式之间切换
旋转锁:禁用线程优先级提升
多处理器的机器旋转锁比较有用,
关键段:先循环一定次数,如果还是无法访问,线程切换至内核模式,直到资源可用
interlockedcompareexchange
方法二:关键段
CRITICAL_SECTION g_cs;
EnterCriticalSection(&g_cs)
…
LeaveCrititalSection(&g_cs)
关键段无法在多个进程之间对线程同步
方法三:Slim读/写锁
和关键段相似,但是区分读取线程和写入线程
SRWLOCK
用内核对象进行线程同步
在进程内核对象内部有一个布尔变量,当系统创建内核对象的时候会把这个变量的值初始化为false(未触发),当进程终止时,操作系统会把相应的内核对象中的值设置为true,表示已经触发。
等待函数:WaitForSingleObject(HANDLE,DWORD)
WaitForMultipleObjects(DWORD,CONST HANDLE* ,BOOL,DWORD)
事件内核对象
让一个线程执行初始化工作,然后出发另一个线程,让它执行余下的工作
createEvent()
OpenEvent()
SetEvent()//触发时
ResetEvetn()
可等待的计数器内核对象
createWaitableTimer()
OpenwaitableTimer()
SetWaitableTimer()//触发时
信号量
互斥量