- 论坛徽章:
- 0
|
1 #include <stdio.h>
2 #include <signal.h>
3 #include <pthread.h>
4
5 pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
6
7 void sig_all(int signum)
8 {
9 pthread_mutex_lock(&mutex);
10 printf("sig_all\n");
11 pthread_mutex_unlock(&mutex);
12 }
13
14 int main()
15 {
16 if (SIG_ERR == signal(SIGINT, sig_all))
17 perror("signal");
18 pthread_mutex_lock(&mutex);
19 printf("__main__\n");
20 sleep(10);
21 printf("__main__\n");
22 pthread_mutex_unlock(&mutex);
23
24 return 0;
25 }
这样写没啥问题呀。单线程不会出问题的呀。
1 #include <stdio.h>
2 #include <signal.h>
3 #include <pthread.h>
4
5 pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
6
7 void sig_all(int signum)
8 {
9 printf("signal...\n");
10 pthread_mutex_lock(&mutex);
11 printf("sig_all\n");
12 pthread_mutex_unlock(&mutex);
13 }
14
15 void* worker(void* args)
16 {
17 pthread_mutex_lock(&mutex);
18 printf("__worker__\n");
19 sleep(10);
20 printf("__worker__\n");
21 pthread_mutex_unlock(&mutex);
22 return (void*)0;
23 }
24
25 int main()
26 {
27 if (SIG_ERR == signal(SIGINT, sig_all))
28 perror("signal");
29 pthread_t tid;
30 if (0 != pthread_create(&tid, NULL, worker, NULL))
31 perror("pthread_create");
32
33 pthread_join(tid, NULL);
34 return 0;
35 }
上面的会出问题。问题在死锁了。进程中的子线程和主线程争夺锁死锁了。
我真不知道你上面测试的单线程怎么会出问题,我觉得只有一种可能就是你的系统里pthread_mutex_t默认不是可重入的。
据我对信号的了解,当进行系统调用的时候检测到信号,系统会返回到信号处理函数,信号处理函数结束之后再返回到进程中系统调用的位置。所以sleep的时候发送信号,返回到信号处理函数,信号处理函数获取锁,但是锁已经被另一个线程占用了。所以需要等待另一个线程,但是另一个线程需要等待信号处理函数执行完成之后才能返回。因此发生死锁。 |
|