Если вы не работаете в 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
) до тех пор, пока не прервется (именно поэтому вы должны обрабатывать ошибки), или сигнализатор пишет байт.