是否可以立即启动由pthread_create
创建的线程而无需等待〜300us才能启动它?现在,现有代码通过向线程发送SIGHUP
来执行线程的“启动”,但是副作用是如果主进程没有为SIGHUP
设置信号处理程序,这个过程就会退出......
我可以让它处理SIGHUP
,但是我想知道是否有更好的解决方案而不是这样做...
注意:问题的初始版本说“300ms”,导致评论300毫秒是非常长的。 300微秒更合理。
答案 0 :(得分:0)
在修补它几个小时后,另一种存档我需要的方式。顺便说一句,我尝试使用sched_yield
作为@nos建议,并没有产生任何不同的行为。
作为更新,我想指出我正在使用的代码正在执行do...while
循环,以通过发送SIGHUP
来探测pthread是否已完成。
我的问题的解决方案是发送自定义sigaction
,如下所示:
有一个虚拟信号处理程序:
void thread_signal_handler(int sig) { }
然后在我正在使用的图书馆中,在发送SIGHUP
:
...
struct sigaction sa;
sa.sa_handler = dummy_handler;
sa.sa_flags = 0;
sigemptyset(&sa.sa_mask);
sigaction(SIGHUP, &sa, NULL);
pthread_kill(tid, SIGHUP);
...
这样做,我的应用程序不需要处理SIGHUP
信号。