线程同步之死锁

 

 

什么是死锁呢?

       死锁就是多个进程或者线程访问同一个资源的时候,谁也抢不到资源,谁也不退让让其他进程或者线程访问,用户看到的就是程序卡住了。举个例子吧,在一个没有红绿灯的十字路口,来了四辆小汽车,每个路口都只能让一个汽车通过。现在这种情况四辆车都过不了汽车,这就发生了死锁。

发生死锁的原因?

第一种情况是重复加锁,在这种情况下,第二个锁到来的时候,发现有锁了,那就会阻塞在这里等待解锁后在加锁,但是从代码看来是不可能的。所以在用的时候一定不能重复加锁,否则就会阻塞。

int num;
void *fun()
{
    while(1)
    {
	pthread_mutex_lock(&mutex);    //加锁
	pthread_mutex_lock(&mutex);    //加锁
	num++;
	printf("num = %d\n",num);      //打印这个全局变量的值
	pthread_mutex_unlock(&mutex);  //解锁
    }

    return NULL;
}

第二种情况如下图,这就如过十字路口一样的道理。

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值