创建线程后让线程定时执行,可以通过sleep(time).
但我们一般可以通过在使用WaitForSingleObject(HANDLE handle, DWORDdwMilliseconds)来等待。
如果不让线程做等待过程的返回操作,便可直接使用线程句柄等待即可。
DWORD WINAPICGisOper::VehStatusThread(LPVOID pParam)
{
…
while(WaitForSingleObject(m_hThread, 3000))
{} //这里线程会一直等待。每隔3秒执行一次。
此时m_hThread的状态:
对于线程来讲,如果线程在运行状态则为无信号状态,在退出后为有信号状态。所以我们可以使用 WaitForSingleObject 来等待线程退出,
Eg: WaitForSingleObject(m_hThread,3000);
Closehandle(m_hThread);
m_hThread = NULL;
}
如果线程在等待过程中需要及时唤醒向下执行,那么一般常用的方法我们可以创建一个事件对象,来触发WaitForSingleObject等待的返回。
如:DWORD WINAPI CGisOper::VehStatusThread(LPVOID pParam)
{
…
while(WaitForSingleObject(m_hEvent, 3000))
{} //这里线程会一直等待。每隔3秒执行一次。
此时可以根据m_hEvent是否有无信号来触发是否返回,如果正在等到过程中,需要在需要返回的时机去触发m_hEvent成为有信号状态则会返回等待。比如点击按钮时,调用SetEvent(m_hEnent)置为有信号状态。
}
因为函数WaitForSingleObject(
HANDLE hHandle, DW
ORD dwMilliseconds)
hHandle对象句柄。可以指定一系列的对象,如Event、Job、Memory resourcenotification、Mutex、Process、Semaphore、Thread、Waitabletimer等,
dwMilliseconds定时时间间隔,单位为milliseconds(毫秒).如果指定一个非零值,函数处于等待状态直到hHandle标记的对象被触发,或者时间到了。如果dwMilliseconds为0,对象没有被触发信号,函数不会进入一个等待状态,它总是立即返回。如果dwMilliseconds为INFINITE,对象被触发信号后,函数才会返回,即若为INFINITE,则线程一直被挂起,直到hHandle所指向的对象变为有信号状态时为止。
也就是说要么被触发一下,告诉函数要返回了,要么超时了才能返回。
创建事件对象:
m_hEvent = CreateEvent(
NULL, /*默认安全性*/
FALSE, /*指定创建的是人工还是自动对象,true人工,false自动*/
FALSE/*事件对象初始状态,true有信号,否则无信号*/
, NULL);
等待线程退出
WaitForSingleObject(m_hThread, 3000);
Closehandle(m_hThread);
m_hThread = NULL;
因为线程执行时m_hThread为无信号状态,返回了才有信号,所以一旦等到句柄状变化,说明线程可以返回了。