Linux多线程基础(4):死锁和trylock函数

本文解释了死锁的概念,通过C++中的pthread_mutex_t和pthread_mutex_lock函数,以及如何使用pthread_mutex_trylock来防止死锁,确保程序正常执行。
摘要由CSDN通过智能技术生成

死锁是指两个或多个进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若不释放锁,程序将无法正常运行。

举个例子:

pthread_mutex_t mutex;
void *pth1(void* str){
    pthread_mutex_lock(&mutex);  //加锁
    pthread_mutex_lock(&mutex);  //加锁
    for(int i=0;i<5;i++){
        number++;
        std::cout<<"线程计划1结果:"<<number<<std::endl;
        usleep(10);
    }    
    pthread_mutex_unlock(&mutex);  //解锁
    pthread_exit(0);
}

这一段代码不小心进行了两次加锁,只有一次解锁,所以就会陷入死锁,导致程序无法正常执行.

为了避免死锁,我们可以引入pthread_mutex_trylock函数,定义如下:

int pthread_mutex_trylock(pthread_mutex_t *mutex);

其中 mutex 是一个指向互斥锁对象的指针。函数返回值:如果成功获取锁,返回 0;如果无法获取锁,则返回一个非零值。

示例:

void *pth1(void* str){
     if (pthread_mutex_trylock(&mutex) == 0) {  
        // 成功获取锁,执行临界区代码  
       for(int i=0;i<5;i++){
        number++;
        std::cout<<"线程计划1结果:"<<number<<std::endl;
        usleep(10);
    }    
    pthread_mutex_unlock(&mutex);  //解锁
    pthread_exit(0);
        // 解锁互斥锁  
        pthread_mutex_unlock(&mutex);  
    } else {  
        // 无法获取锁  
        printf(" failed to lock the mutex\n");  
    }   
}

通过添加pthread_mutex_trylock进行判断,就不会出现死锁的问题.

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值