Liunx系统编程篇—多线程编程(三)(关于互斥锁)互斥锁什么时候发生死锁?

互斥锁什么时候发生死锁?

在线程间共享多个资源的时候,如果两个线程分别占有一部分资源并且同时等待对方的资源,就会造成死锁,尽管死锁很少发生,但一旦发生就会造成应用的停止响应。

注:死锁一般发生在程序存在2个锁以上的情况。

实例:

#include <stdio.h>
#include <pthread.h>
//int pthread_mutex_init(pthread_mutex_t *restrict mutex, const pthread_mutexattr_t *restrict attr);
int a=0;
pthread_mutex_t mutex;
pthread_mutex_t mutex2;
void *func1(void *arg)
{
        pthread_mutex_lock(&mutex);//锁1上锁
        sleep(1);
        pthread_mutex_lock(&mutex2);//锁2上锁
        a++;
        printf("t1:a=%d\n",a++);
        printf("t1:a=%d\n",a);
        pthread_mutex_unlock(&mutex);
}
void *func2(void *arg)
{
        pthread_mutex_lock(&mutex2);//锁2上锁
        sleep(1);
        pthread_mutex_lock(&mutex);//锁1上锁
        a++;
        printf("t2:a=%d\n",a++);
        printf("t2:a=%d\n",a);
        pthread_mutex_unlock(&mutex);
}
int main()
{
        int ret1=0;
        int ret2=0;
        pthread_t t1;
        pthread_t t2;
        pthread_mutex_init(&mutex, NULL);
        pthread_mutex_init(&mutex2, NULL);
        ret1=pthread_create(&t1,NULL,func1,NULL);
        ret2=pthread_create(&t2,NULL,func2,NULL);
        if((ret1||ret2)!=0){
                printf("main:create thread failure\n");
        }
                a++;
                printf("main:a=%d\n",a);
                sleep(2);
        pthread_mutex_destroy(&mutex);
        return 0;
}

实验结果:

线程1和线程2被锁死
在这里插入图片描述

实验解析:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值