POSIX 多线程和信号处理
POSIX multithreading and signal disposition
这是我的代码:
void handler(int sig)
{
printf("%lu recv signal\n", pthread_self());
}
void* thread_fun(void *threadid)
{
printf("thread %lu created\n", pthread_self());
while(1){
sleep(1);
}
return NULL;
}
int main(void)
{
struct sigaction act;
act.sa_handler = handler;
sigemptyset(&act.sa_mask);
act.sa_flags = 0;
sigaction(SIGINT, &act, NULL);
printf("thread %lu created\n", pthread_self());
pthread_t t1,t2;
pthread_create(&t1, NULL, thread_fun, NULL);
pthread_create(&t2, NULL, thread_fun, NULL);
while(1)
sleep(1);
return 0;
}
APUE表示在多线程进程中,像SIGINT这样的信号会被传递到一个随机线程,但是,当我运行这个代码在Ubuntu 14.04,好像信号一直是传递给主线程的。有谁知道问题出在哪里?
"Random thread" 并不意味着它被传递到随机选择的线程,而是它可以被传递到实现者想要的任何线程。所以随机选择是可能的,但任何其他选择都是可能的。在您的系统上,选择是:如果可能,主线程优先。
您可以阅读
OpenGroup Signal Concepts document。没有 "random" 选项。据说在所有线程中会选择一个不阻塞信号或正在等待信号的线程。
所以你唯一应该考虑的是可能任何线程都可以接收信号。
这是我的代码:
void handler(int sig)
{
printf("%lu recv signal\n", pthread_self());
}
void* thread_fun(void *threadid)
{
printf("thread %lu created\n", pthread_self());
while(1){
sleep(1);
}
return NULL;
}
int main(void)
{
struct sigaction act;
act.sa_handler = handler;
sigemptyset(&act.sa_mask);
act.sa_flags = 0;
sigaction(SIGINT, &act, NULL);
printf("thread %lu created\n", pthread_self());
pthread_t t1,t2;
pthread_create(&t1, NULL, thread_fun, NULL);
pthread_create(&t2, NULL, thread_fun, NULL);
while(1)
sleep(1);
return 0;
}
APUE表示在多线程进程中,像SIGINT这样的信号会被传递到一个随机线程,但是,当我运行这个代码在Ubuntu 14.04,好像信号一直是传递给主线程的。有谁知道问题出在哪里?
"Random thread" 并不意味着它被传递到随机选择的线程,而是它可以被传递到实现者想要的任何线程。所以随机选择是可能的,但任何其他选择都是可能的。在您的系统上,选择是:如果可能,主线程优先。
您可以阅读 OpenGroup Signal Concepts document。没有 "random" 选项。据说在所有线程中会选择一个不阻塞信号或正在等待信号的线程。
所以你唯一应该考虑的是可能任何线程都可以接收信号。