[英]Efficiently wait for a flag state change without blocking resources?
線程無限循環地等待直到標志狀態改變,然后調用函數。
偽代碼插圖:
while (true)
{
while (!flag)
{
sleep(1);
}
clean_upfunction();
}
目前 :
沒有:
題:
對於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。
它是便攜式的,比特定於平台的選件更易於使用。 而且,IIUC是即將建模的即將發布的C ++ 0x std :: condition_variable。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.