什么情况造成死锁
1.什么是死锁:
由于互斥锁使用不当,导致多个进程无法进行下一步代码的运行。
即:两个互斥锁卡住了,以至于其它线程无法使用共享资源
2.什么情况造成死锁:
前提条件:你有2个锁,
当线程A获得一把锁的时候,想要获得另外一把锁,而线程B使用着线程A想要的锁,还想要获得线程A正在使用的锁的时候。
参考代码:
#include <stdio.h>
#include <pthread.h>
int g_data=0;//共享资源
pthread_mutex_t mutex;//创建互斥锁1(互斥量)
pthread_mutex_t mutex2;//创建互斥锁2(互斥量)
void *func1(void*arg)//参数3:调用无类型指针API
{
int i;
pthread_mutex_lock(&mutex);//加锁
sleep(1);//确保线程2获得锁2
pthread_mutex_lock(&mutex2);//加锁2
for(i=0;i<5;i++)
{
printf("t1:%ld thread is create\n",(unsigned long)pthread_self());
//pthread_self():返回自身线程id,为pthread_t类型
printf("t1:param is %d:\n",*((int*)arg));//转化为int*,再取值
sleep(1);
}
pthread_mutex_unlock(&mutex);//解锁,别的线程可以上了
}
void *func2(void*arg)//参数3:调用无类型指针API
{
pthread_mutex_lock(&mutex2);//加锁2
sleep(1);//确保线程1获得锁1
pthread_mutex_lock(&mutex);//加锁
printf("t2:%ld thread is create\n",(unsigned long)pthread_self());
//pthread_self():返回自身线程id,为pthread_t类型
printf("t2:param is %d:\n",*((int*)arg));//转化为int*,再取值
}//大家都拿不到另外一把想要的锁,就会造成死锁
int main()
{
int ret;//返回值
pthread_t t1;
pthread_t t2;
pthread_mutex_init(&mutex,NULL);//参数2:锁的属性
pthread_mutex_init(&mutex2,NULL);//初始化
int param=100;//参数4:调用时:将int*转化为void*.100:随便给的数
ret=pthread_create(&t1,NULL,func1,(void*)¶m);
//参数1:指针指向t1,NULL:线程属性,参数3:启动线程调用的函数,参数4:打印的值
ret=pthread_create(&t2,NULL,func2,(void*)¶m);
if(ret==0)
{
printf("main函数创建线程t1成功\n");
}
if(ret==0)
{
printf("main函数创建线程t2成功\n");
}
printf("main:%ld\n",(unsigned long)pthread_self());
pthread_join(t1,NULL);//等待线程
pthread_join(t2,NULL);//等待线程
pthread_mutex_destroy(&mutex);//销毁这把锁
pthread_mutex_destroy(&mutex2);//销毁这把锁
return 0;
}
运行结果:
dazai@dazai:~$ gcc demo3.c -lpthread
dazai@dazai:~$ ./a.out
main函数创建线程t1成功
main函数创建线程t2成功
main:-1210755328
注:运行结果执行到一半锁死