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

2024-01-09 17:05:47

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

举个例子:

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进行判断,就不会出现死锁的问题.

文章来源:https://blog.csdn.net/shnhe/article/details/135397125
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。