线程6:什么情况造成死锁

什么情况造成死锁

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*)&param);
 //参数1:指针指向t1,NULL:线程属性,参数3:启动线程调用的函数,参数4:打印的值
 ret=pthread_create(&t2,NULL,func2,(void*)&param);
 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

注:运行结果执行到一半锁死

猜你喜欢

转载自blog.csdn.net/weixin_40734514/article/details/108542361