SleepEx,SleepEx函数中止当前
线程运行直到指定的条件被触发。当以下任意一点出现时,当前
线程将恢复运行。
函数原型
DWORD WINAPI SleepEx(DWORD dwMilliseconds,BOOL bAlertable);
说明
● Asynchronous Procedure Call(APC)异步函数被插入线程
● 当前线程休眠时间超过最小超时值
参数说明
dwMilliseconds
单位毫秒,线程休眠的时间。
如果该值设为0,当前线程将放弃它剩余的执行时间片,并将时间片平均分给与它同等级的其它线程。如果当前进程没有与它同等级的线程运行,该函数SleepEx立即返回,线程继续执行。
如果INFINITE值被指定,当前线程的休眠不会超时。
bAlertable
如果该参数为FALSE,函数不会返回直到超时已到。如果一个I/O
回调函数出现,该函数也不会返回而且回调函数也不会执行。如果一个APC函数插入线程,该函数不会返回而且APC函数也不会执行。
如果该参数为TRUE而且SleepEx与扩展I/O函数(
ReadFileEx or
WriteFileEx)是在同一个线程,函数就会立即返回当线程休眠超时或I/O
回调函数出现。如果I/O
回调函数出现,那么I/O回调函数会被调用。如果APC被插入线程,该函数不论当前线程是否超时都会立即执行,而且APC函数也会被调用。
返回值
当线程休眠超时函数返回0。
如果函数返是由于I/O回调函数导致,那么返回值是WAIT_IO_COMPLETION,这只会出现在当bAlertable设置TRUE时的情况。
示例
DWORD WINAPI Reader(PVOID dummy) //线程
{
ULONG data;
OVERLAPPED ov;
while(!ExitFlag)
{
ZeroMemory( &ov, sizeof(ov) );
ov.Offset = 0;
ov.OffsetHigh = 0;
if(!
ReadFileEx(hDevice, (PVOID)&data, sizeof(ULONG), &ov, CompletionRoutine))
{
ExitProcess ( 1 );
}
SleepEx(INFINITE, TRUE);
}
ExitThread(0);
return 0;
}
VOID CALLBACK CompletionRoutine( //
回调函数DWORD errorcode,
DWORD bytesTransfered,
LPOVERLAPPED ov
)
{
GetCurrentThreadId(), bytesTransfered);
return;
}