术语 | sleepex |
释义 | SleepEx 语法: C++ DWORD WINAPI SleepEx( __in DWORD dwMilliseconds, __in BOOL bAlertable ); SleepEx功能 直到指定的条件当前线程挂起满足。恢复执行时出现下列情况之一: 一个/ O完成回调函数被调用我 异步过程调用(APC)是排队到线程。 在超时间隔经过的时间 参数 dwMilliseconds的 [in] 时间间隔的执行被暂停以毫秒为单位。 值为零会导致线程放弃其剩余的时间片同等优先的任何其他线程准备运行。如果有一个平等的优先权没有现成的其他线程运行,函数立即返回,并继续执行线程。 无限的值表示暂时不要超时。 bAlertable [in] 如果此参数为FALSE,该函数不返回,直到超时时间已过。如果发生I / O完成回调时,该函数不返回和/ O完成的功能是不执行我。如果APC是排队到线程,该函数不返回的APC功能不会被执行。 如果该参数为TRUE的线程调用这个函数的线程中调用扩展I / O函数(ReadFileEx或WriteFileEx),该函数返回时,无论是超时时间已过或当一个I / O完成回调功能发生。如果发生I / O完成回调时,该I / O完成函数。如果APC被排队的线程(QueueUserAPC),该函数返回时,无论是计时器超时期限已过,或者当APC函数。 返回值 在返回值为0,如果在指定的时间间隔过期。 返回值是WAIT_IO_COMPLETION如果由于函数返回一个或多个I / O完成回调函数。发生这种情况只有在bAlertable为TRUE,如果线程被称为SleepEx功能是相同的线程称为扩展的I / O功能。 备注 这个函数导致线程放弃其剩余的时间片,并成为对dwMilliseconds的值为基础的间隔unrunnable。该系统时钟“滴答”,以恒定速率。如果dwMilliseconds的比对系统时钟的决议,则该线程可能睡眠的时间超过了规定的长度。如果dwMilliseconds的大于一剔,但不超过两分,等待可以在任何地方一至二扁虱等。为了增加睡眠时间间隔的准确性,调用timeGetDevCaps函数来确定支持的最低计时器决议和timeBeginPeriod函数来设置计时器分辨率最低限度。使用时要小心调用timeBeginPeriod,例如经常调用可以极大地影响系统时钟,系统功耗和调度。如果您调用timeBeginPeriod,称之为一次在应用初期,并务必调用应用程序非常结束timeEndPeriod功能。 睡眠时间间隔后,已通过,线程准备运行。如果指定0毫秒,线程将放弃其剩余时间片,但仍准备。请注意,一个现成的线程不能保证立即运行。因此,线程可能无法运行,直到一些睡眠时间间隔后,经过的时间。有关更多信息,请参阅调度优先级。 此功能可用于在ReadFileEx或WriteFileEx功能之前,暂停1 / O操作完成后,我一个线程。这些函数指定一个完成例程被执行时,I / O操作已经完成。为了完成例程被执行的线程被称为I / O函数,必须在一个可报警等待状态时完成的回调函数发生。一个线程去到一个可报警等待状态通过调用SleepEx,MsgWaitForMultipleObjectsEx,WaitForSingleObjectEx,或WaitForMultipleObjectsEx,与函数的bAlertable参数设置为TRUE。 小心使用SleepEx和代码直接或间接产生的窗口。如果一个线程创建的窗口,它必须处理消息。广播消息发送到系统中的所有窗口。如果您有一个线程使用具有无穷时滞SleepEx,系统将僵局。两个代码,间接创造DDE的窗口和COM CoInitialize例子。因此,如果您有一个线程创建的窗口,使用,而非SleepEx MsgWaitForMultipleObjects或MsgWaitForMultipleObjectsEx。 要求: 最低支持:client-Windows 2000专业版 最低支持server-Windows 2000服务器 HeaderWinbase.h(头文件:winuser.h) LibraryKernel32.lib DLLKernel32.dll 参见 MsgWaitForMultipleObjects MsgWaitForMultipleObjectsEx 进程和线程函数 QueueUserAPC ReadFileEx 睡觉 暂停线程的执行 主题 WaitForMultipleObjectsEx WaitForSingleObjectEx WriteFileEx 如果有任何问题和意见,请发送给微软(wsddocfb@microsoft.com) 生成日期:2009年8月27日 ==英文原文==SleepEx Function Suspends the current thread until the specified condition is met. Execution resumes when one of the following occurs: An I/O completion callback function is called An asynchronous procedure call (APC) is queued to the thread. The time-out interval elapses Syntax C++ DWORD WINAPI SleepEx( __in DWORD dwMilliseconds, __in BOOL bAlertable ); Parameters dwMilliseconds [in] The time interval for which execution is to be suspended, in milliseconds. A value of zero causes the thread to relinquish the remainder of its time slice to any other thread of equal priority that is ready to run. If there are no other threads of equal priority ready to run, the function returns immediately, and the thread continues execution. A value of INFINITE indicates that the suspension should not time out. bAlertable [in] If this parameter is FALSE, the function does not return until the time-out period has elapsed. If an I/O completion callback occurs, the function does not return and the I/O completion function is not executed. If an APC is queued to the thread, the function does not return and the APC function is not executed. If the parameter is TRUE and the thread that called this function is the same thread that called the extended I/O function ( ReadFileEx or WriteFileEx ), the function returns when either the time-out period has elapsed or when an I/O completion callback function occurs. If an I/O completion callback occurs, the I/O completion function is called. If an APC is queued to the thread ( QueueUserAPC ), the function returns when either the timer-out period has elapsed or when the APC function is called. Return Value The return value is zero if the specified time interval expired. The return value is WAIT_IO_COMPLETION if the function returned due to one or more I/O completion callback functions. This can happen only if bAlertable is TRUE, and if the thread that called the SleepEx function is the same thread that called the extended I/O function. Remarks This function causes a thread to relinquish the remainder of its time slice and become unrunnable for an interval based on the value of dwMilliseconds. The system clock "ticks" at a constant rate. If dwMilliseconds is less than the resolution of the system clock, the thread may sleep for less than the specified length of time. If dwMilliseconds is greater than one tick but less than two, the wait can be anywhere between one and two ticks, and so on. To increase the accuracy of the sleep interval, call the timeGetDevCaps function to determine the supported minimum timer resolution and the timeBeginPeriod function to set the timer resolution to its minimum. Use caution when calling timeBeginPeriod, as frequent calls can significantly affect the system clock, system power usage, and the scheduler. If you call timeBeginPeriod, call it one time early in the application and be sure to call the timeEndPeriod function at the very end of the application. After the sleep interval has passed, the thread is ready to run. If you specify 0 milliseconds, the thread will relinquish the remainder of its time slice but remain ready. Note that a ready thread is not guaranteed to run immediately. Consequently, the thread may not run until some time after the sleep interval elapses. For more information, see Scheduling Priorities . This function can be used with the ReadFileEx or WriteFileEx functions to suspend a thread until an I/O operation has been completed. These functions specify a completion routine that is to be executed when the I/O operation has been completed. For the completion routine to be executed, the thread that called the I/O function must be in an alertable wait state when the completion callback function occurs. A thread goes into an alertable wait state by calling either SleepEx, MsgWaitForMultipleObjectsEx , WaitForSingleObjectEx , or WaitForMultipleObjectsEx , with the function's bAlertable parameter set to TRUE. Be careful when using SleepEx and code that directly or indirectly creates windows. If a thread creates any windows, it must process messages. Message broadcasts are sent to all windows in the system. If you have a thread that uses SleepEx with infinite delay, the system will deadlock. Two examples of code that indirectly creates windows are DDE and COM CoInitialize. Therefore, if you have a thread that creates windows, use MsgWaitForMultipleObjects or MsgWaitForMultipleObjectsEx , rather than SleepEx. Requirements Minimum supported clientWindows 2000 Professional Minimum supported serverWindows 2000 Server HeaderWinbase.h (include Windows.h) LibraryKernel32.lib DLLKernel32.dll See Also MsgWaitForMultipleObjects MsgWaitForMultipleObjectsEx Process and Thread Functions QueueUserAPC ReadFileEx Sleep Suspending Thread Execution Threads WaitForMultipleObjectsEx WaitForSingleObjectEx WriteFileEx Send comments about this topic to Microsoft Build date: 8/27/2009 ==原始网址==http://msdn.microsoft.com/en-us/library/ms686307(VS.85).aspx\n |
随便看 |
|
windows api函数参考手册包含2258条windows api函数文档,详细介绍nodejs、java、rust调用windows api的方法技巧,是学习windows api编程的入门中文文档。