函数原型为:
DWORD WaitForSingleObject(HANDLE hHandle,DWORD dwMilliseconds);

hHandle为要监视的对象(一般为同步对象,也可以是线程)的句柄;
dwMilliseconds为hHandle对象所设置的超时值,单位为毫秒;
  当在某一线程中调用该函数时,线程暂时挂起,系统监视hHandle所指向的对象的状态。如果在挂起的dwMilliseconds毫秒内,线程所等待的对象变为有信号状态,则该函数立即返回;如果超时时间已经到达dwMilliseconds毫秒,但hHandle所指向的对象还没有变成有信号状态,函数照样返回。参数dwMilliseconds有两个具有特殊意义的值:0和INFINITE。若为0,则该函数立即返回;若为INFINITE,则线程一直被挂起,直到hHandle所指向的对象变为有信号状态时为止。


所以第一个::WaitForSingleObject()函数便返回,释放了该线程对Mutex的拥有权,Mutex又会变成激发态,这样就导致了第二个::WaitForSingleObject()函数的返回!

 

 

主要区分

CreateEvent

CreateMutex

的区别。mutex是互斥量, event就是用来事件通知的。

因为mutex里面的ReleaseMutex是将设置为没有线程拥有它,有信号;而event里面的resetevent是将设置为无信号.

 

老奎哥:

mutex是互斥量, 一般用在程序只允许系统里面有一个instance的时候,程序一启动就检测这个mutex, 如果有说明该程序已经在运行, 就退出. 否则own这个mutex并继续运行程序
event一般用在通知, 比如一个事情做完了通知另一个线程, 这里的另一个线程一般是在wait这个event
mutex是保护临界区的, 当然你非要拿它等待 事件, 也可以, 但语义不同

就是进程的一个实例. 比如记事本(假设), 第一个记事本启动的时候,mutex没有被创建, 所以第一个记事本程序创建并拥有该mutex, 然后显示UI.然后第二个记事本启动的时候, 发现mutex已经存在, 说明已经有记事本在运行了,那么第二个记事本直接退出.  这样保证系统里只有一个instance