- 子线程会继承父线程的 sigmask
- sigaction 的作用范围是整个进程,在某个线程中修改,也会影响到整个进程
- 每个线程都有自己的 sigmask,通过 pthread_sigmask 设置,多线程程序中 sigprocmask 行为不确定,推荐使用 pthread_sigmask
示例代码
// 屏蔽信号
void signal_lock (sigset_t *save) {
sigset_t set;
sigfillset(&set); /* fill `set` with __all__ signals */
sigprocmask(SIG_BLOCK, &set, save); /* no more signals :-) */
}
//放开屏蔽
void signal_unlock (sigset_t *save) {
sigprocmask(SIG_SETMASK, save, NULL); /* enable again */
}
int main()
{
sigset_t tmp;
signal_lock(&tmp); /* we locked all signals --
* no signal will arrives until signal_unlock() */
pthread_mutex_lock(<pthread_mutex_t*>);
/* do your stuff */
pthread_mutex_unlock(<pthread_mutex_t*>);
signal_unlock(&tmp); /* unlock signals --
* only signals allowed before signal_lock()
* may arrive */
}
参考
https://stackoverflow.com/questions/30890526/linux-pthread-cond-signal-is-not-working-inside-a-signal-handler
728

被折叠的 条评论
为什么被折叠?



