簡體   English   中英

有效地等待標志狀態更改而不會阻塞資源?

[英]Efficiently wait for a flag state change without blocking resources?

線程無限循環地等待直到標志狀態改變,然后調用函數。

偽代碼插圖:

while (true)
{
    while (!flag)
    {
            sleep(1);
    }
    clean_upfunction();
}

目前

沒有:

  • MFC

題:

  • 是否有一種更有效的方法來實現上述目的
  • 線程庫中的waitForStateChange()-與上面類似-

對於Windows(已對此進行了標記),您需要查看WaitForSingleObject 使用Windows事件(帶有CreateEvent),然后等待它; 另一個線程應調用SetEvent。 所有本機Windows,不需要MFC或其他任何東西。

如果您不在Windows上,而是在POSIXish框上,則pthread_cond_wait是最佳匹配:

/* signaler */
    pthread_mutex_lock(mutex);
    flag = true;
    pthread_cond_signal(cond);
    pthread_mutex_unlock(mutex);

/* waiter */
    pthread_mutex_lock(mutex);
    do {
        pthread_cond_wait(cond, mutex);
    } while (!flag);
    pthread_mutex_unlock(mutex);

經典的自管道技巧雖然更容易也更酷:)也可以在沒有pthreads系統上使用。

/* setup */
    int pipefd[2];
    if (pipe(pipefd) < 0) {
        perror("pipe failed");
        exit(-1);
    }

/* signaler */
    char byte = 0;
    write(pipefd[0], &byte, 1);  // omitting error handling for brevity

/* waiter */
    char byte;
    read(pipefd[1], &byte, 1);  // omitting error handling for brevity

服務員將阻塞read (您不設置O_NONBLOCK ),直到被中斷(這就是您應該進行錯誤處理的原因)或發信號器寫入一個字節為止。

看一下Boost.Thread中的condition_variable。

http://www.boost.org/doc/libs/1_37_0/doc/html/thread/synchronization.html#thread.synchronization.condvar_ref

它是便攜式的,比特定於平台的選件更易於使用。 而且,IIUC是即將建模的即將發布的C ++ 0x std :: condition_variable。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM