我有一个C程序,我使用pthread。
我希望新创建的线程在创建后立即运行。
这背后的原因是我的线程有初始化代码来设置信号处理程序,在主线程发送一些信号之前,我必须确保处理程序已准备就绪。
我在pthread_yield
之后尝试pthread_create
,但没有成功。
我怀疑它有所不同,但我在x86_64上运行Linux 3.6。
由于
答案 0 :(得分:5)
或者您可以使用屏障,即调用pthread_barrier_wait(在每个线程的例程中,或者在主线程中初始化),以确保每个相关线程都已到达屏障(之后一些你的线程可以做你顽皮的信号技巧)。请参阅this question。
答案 1 :(得分:5)
如果您的目标是让主线程等待所有线程在继续之前达到相同的点,我建议使用pthread_barrier_wait
:
void worker(void*);
int main(int argc, char **argv)
{
pthread_barrier_t b;
pthread_t children[TCOUNT];
int child;
/* +1 for our main thread */
pthread_barrier_init(&b, NULL, TCOUNT+1);
for (child = 0; child < TCOUNT; ++child)
{
pthread_create(&children[child], NULL, worker, &b);
}
printf("main: children created\n");
/* everybody who calls barrier_wait will wait
* until TCOUNT+1 have called it
*/
pthread_barrier_wait(&b);
printf("main: children finished\n");
/* wait for children to finish */
for (child = 0; child < TCOUNT; ++child)
{
pthread_join(&children[child], NULL);
}
/* clean-up */
pthread_barrier_destroy(&b);
return 0;
}
void worker(void *_b)
{
pthread_barrier_t *b = (pthread_barrier_t*)_b;
printf("child: before\n");
pthread_barrier_wait(b);
printf("child: after\n");
}