关闭计时器从工作线程处理

时间:2012-09-12 11:32:31

标签: c++ winapi msdn atlcom

提出问题的最佳方式是首先展示一个例子:

这是我在c ++中创建计时器的方式:

        if (FALSE == CreateTimerQueueTimer(&m_hSampleStarvationTimer,
                                            m_hSampleStarvationTimerQueue,
                                            (WAITORTIMERCALLBACK)TsSampleStarvationTimeBomb_Static,
                                            (LPVOID)this,
                                            dwDueTime,
                                            0,
                                            WT_EXECUTEONLYONCE))

一旦触发了以下回调(TsSampleStarvationTimeBomb_Static),我会尝试杀死该特定线程中的队列句柄和计时器句柄。

void CALLBACK CCaptureChannel::TsSampleStarvationTimeBomb_Static(LPVOID lpArg, BOOLEAN TimerOrWaitFired)
    {
        HRESULT hr;
        BOOL    bHandleDeletion          = FALSE;
        CCaptureChannel* pCaptureChannel = (CCaptureChannel*)lpArg;

        ATLASSERT(pCaptureChannel);

        bHandleDeletion = DeleteTimerQueueTimer(pCaptureChannel->m_hSampleStarvationTimerQueue, pCaptureChannel->m_hSampleStarvationTimer, NULL);
        bHandleDeletion = DeleteTimerQueue(pCaptureChannel->m_hSampleStarvationTimerQueue);

我的问题是:它有效吗?我在MSDN上读到以下删除函数可能会返回i / o错误,这些错误不应该让我太过关注。一旦回调线程自动转向,就会执行它们的终止。

我是对的吗? 谢谢!

1 个答案:

答案 0 :(得分:1)

一旦所有计时器回调完成,DeleteTimerQueueEx将取消并删除与队列关联的所有计时器,因此只需调用DeleteTimerQueueEx即可。您不需要调用DeleteTimerQueueTimer。如果您在代码中调用回调内部,则必须将NULL作为CompletionEvent参数传递,以避免死锁。