死锁是指两个或多个进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若不释放锁,程序将无法正常运行。
举个例子:
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进行判断,就不会出现死锁的问题.