WaitForSingleObject的用法(2006-10-7 12:35:00)

本文详细介绍了Windows API函数WaitForSingleObject的使用方法及其应用场景。该函数可用于等待特定对象变为有信号状态,适用于多种同步机制如事件、互斥量等。文章通过示例展示了如何在多线程环境中利用此函数实现线程间的同步。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

WaitForSingleObject的用法(2006-10-7 12:35:00)

 

 

WaitForSingleObject的用法                     

 

WaitForSingleObject的用法

DWORD WaitForSingleObject(

 

  HANDLE hHandle,

 

  DWORD dwMilliseconds

 

);

 

参数hHandle是一个事件的句柄,第二个参数dwMilliseconds是时间间隔。如果时间是有信号状态返回WAIT_OBJECT_0,如果时间超过dwMilliseconds值但时间事件还是无信号状态则返回WAIT_TIMEOUT

hHandle可以是下列对象的句柄:

    Change notification 
Console input 
Event 
Job 
Memory resource notification 
Mutex 
Process 
Semaphore 
Thread 
Waitable timer

 

 

 

 

 

 

 

WaitForSingleObject函数用来检测hHandle事件的信号状态,当函数的执行时间超过dwMilliseconds就返回,但如果参数dwMillisecondsINFINITE时函数将直到相应时间事件变成有信号状态才返回,否则就一直等待下去,直到WaitForSingleObject有返回直才执行后面的代码。在这里举个例子:

先创建一个全局Event对象g_event:

    CEvent g_event;

在程序中可以通过调用CEvent::SetEvent设置事件为有信号状态。

下面是一个线程函数MyThreadPro()

UINT CFlushDlg::MyThreadProc( LPVOID pParam )

 

 

 

 

 

 

 

{

 

 

 

 

 

 

 

     WaitForSingleObject(g_event,INFINITE);

 

 

 

 

 

 

 

     For(;;)

 

 

 

 

 

 

 

        {

 

 

 

 

 

 

 

         ………….

 

 

 

 

 

 

 

        }

 

 

 

 

 

 

 

     return 0;

 

 

 

 

 

 

 

}

 

 

 

 

 

 

 

在这个线程函数中只有设置g_event为有信号状态时才执行下面的for循环,因为g_event是全局变量,所以我们可以在别的线程中通过g_event. SetEvent控制这个线程。

 

 

 

 

 

 

 

 

 

还有一种用法就是我们可以通过WaitForSingleObject函数来间隔的执行一个线程函数的函数体

     UINT CFlushDlg::MyThreadProc( LPVOID pParam )

 

 

 

 

 

 

 

{

 

 

 

 

 

 

 

     while(WaitForSingleObject(g_event,MT_INTERVAL)!=WAIT_OBJECT_0)

 

 

 

 

 

 

 

     {

 

 

 

 

 

 

 

         ………………

 

 

 

 

 

 

 

     }

 

 

 

 

 

 

 

     return 0;

 

 

 

 

 

 

 

}

 

 

 

 

 

 

 

在这个线程函数中可以可以通过设置MT_INTERVAL来控制这个线程的函数体多久执行一次,当事件为无信号状态时函数体隔MT_INTERVAL执行一次,当设置事件为有信号状态时,线程就执行完毕了。

Log initialized. Vehicle Logger started. 1 6 : 5 5 : 1 0 . 7 0 4 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 0 m 1 6 : 5 5 : 1 1 . 7 0 4 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 0 4 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 0 5 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 0 5 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 0 5 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 0 6 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 0 6 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 0 6 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 6 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 8 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 8 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 9 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 2 9 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 0 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 1 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 1 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 2 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 2 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 2 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 4 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 4 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 4 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 4 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 4 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 5 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 5 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 5 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 5 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 5 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 5 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 6 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 6 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 6 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 6 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 6 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 7 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 3 8 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 4 m 1 6 : 5 5 : 1 1 . 7 4 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 5 m 1 6 : 5 5 : 1 1 . 7 6 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 5 m 1 6 : 5 5 : 1 1 . 7 8 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 5 m 1 6 : 5 5 : 1 1 . 8 0 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 5 m 1 6 : 5 5 : 1 1 . 8 2 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 6 m 1 6 : 5 5 : 1 1 . 8 4 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 6 m 1 6 : 5 5 : 1 1 . 8 6 2 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 6 m 1 6 : 5 5 : 1 1 . 8 8 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 6 m 1 6 : 5 5 : 1 1 . 9 0 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 7 m 1 6 : 5 5 : 1 1 . 9 2 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 7 m 1 6 : 5 5 : 1 1 . 9 4 2 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 7 m 1 6 : 5 5 : 1 1 . 9 6 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 8 m 1 6 : 5 5 : 1 1 . 9 8 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 8 m 1 6 : 5 5 : 1 2 . 0 0 2 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 8 m 1 6 : 5 5 : 1 2 . 0 2 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 8 m 1 6 : 5 5 : 1 2 . 0 4 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 9 m 1 6 : 5 5 : 1 2 . 0 6 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 9 m 1 6 : 5 5 : 1 2 . 0 8 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 1 9 m 1 6 : 5 5 : 1 2 . 1 0 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 2 0 m 1 6 : 5 5 : 1 2 . 1 2 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 2 0 m 1 6 : 5 5 : 1 2 . 1 4 2 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 2 0 m 1 6 : 5 5 : 1 2 . 1 6 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 2 0 m 1 6 : 5 5 : 1 2 . 1 8 2 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 2 1 m 1 6 : 5 5 : 1 2 . 2 0 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 2 1 m 1 6 : 5 5 : 1 2 . 2 2 3 - S p e e d : 5 1 k m / h , T o t a l D i s t a n c e : 2 1 m 1 6 : 5 5 : 1 2 . 2 4 2 - S p e e d : 1 0 7 k m / h , T o t a l D i s t a n c e : 2 2 m 1 6 : 5 5 : 1 2 . 2 6 3 - S p e e d : 1 0 7 k m / h , T o t a l D i s t a n c e : 2 2 m 1 6 : 5 5 : 1 2 . 2 8 3 - S p e e d : 1 0 7 k m / h , T o t a l D i s t a n c e : 2 3 m 1 6 : 5 5 : 1 2 . 3 0 3 - S p e e d : 1 0 7 k m / h , T o t a l D i s t a n c e : 2 3 m 1 6 : 5 5 : 1 2 . 3 2 3 - S p e e d : 1 0 7 k m / h , T o t a l D i s t a n c e : 2 4 m 日志时间戳应该间隔20ms变化一次 为什么最开始会连续打印那么多次,到后面才趋于平稳
最新发布
08-08
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值