死锁产生实例,两个线程两个互斥锁,每个线程占有一个互斥锁,同时想获得另一个互斥锁则会产生死锁。
解决方案:
1.一次占有全部资源
2.每个线程占有锁的顺序是一致的。比如都是同时占有A,然后占有B锁。
#include <stdio.h> #include <stdlib.h> #include <sys/types.h> #include <pthread.h> #include <signal.h>pthread_mutex_t mutex_one,mutex_two; pthread_mutex_t mutex; pthread_cond_t cond;void *thread_routine_one(void *arg) { pthread_cond_wait(&cond,&mutex);//确保two线程先运行 printf("thread_routine_one: lock mutex_one!\n"); pthread_mutex_lock(&mutex_one);printf("thread_routine_one: lock mutex_two!\n"); pthread_mutex_lock(&mutex_two);//获取two锁,这个要等待two线程对two锁的释放 sleep(1); printf("thread_routine_one: unlock mutex_two!\n"); pthread_mutex_unlock(&mutex_two);printf("thread_routine_one: unlock mutex_one!\n"); pthread_mutex_unlock(&mutex_one);return NULL;}void *thread_routine_two(void *arg) { printf("thread_routine_two: lock mutex_two!\n"); pthread_mutex_lock(&mutex_two);//获取two锁 pthread_cond_signal(&cond);//让one线程运行 sleep(1);//休眠,让one可以先运行获取one锁 printf("thread_routine_two: lock mutex_one!\n");pthread_mutex_lock(&mutex_one);//获取one锁,这个同样必须等待one线程多one锁的释放/**这时出现死锁现象了,在two线程要等待one线程对one锁的释放,同时two锁没有释放 * * 然而在one线程需要等待two线程对two锁的释放,然后才会对one锁的释放!出现相互等待的过程**/printf("thread_routine_two: unlock mutex_one!\n"); pthread_mutex_unlock(&mutex_one);printf("thread_routine_two: unlock mutex_two!\n"); pthread_mutex_unlock(&mutex_two);return NULL;}void main() { pthread_t pthread_one,pthread_two;pthread_mutex_init(&mutex_one,NULL); pthread_mutex_init(&mutex_two,NULL); pthread_mutex_init(&mutex,NULL); pthread_cond_init(&cond,NULL);pthread_create(&pthread_one,NULL,thread_routine_one,NULL); pthread_create(&pthread_two,NULL,thread_routine_two,NULL);while(1) sleep(1);}