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
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!