C语言多线程开发中死锁与读写锁问题怎么解决
发表于:2025-01-30 作者:千家信息网编辑
千家信息网最后更新 2025年01月30日,今天小编给大家分享一下C语言多线程开发中死锁与读写锁问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,
千家信息网最后更新 2025年01月30日C语言多线程开发中死锁与读写锁问题怎么解决
今天小编给大家分享一下C语言多线程开发中死锁与读写锁问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
死锁
有时,一个线程需要同时访问两个或更多不同的共享资源,而每个资源又都由不同的互斥量管理。当超过一个线程加锁同一组互斥量时,就有可能发生死锁;
两个或两个以上的进程在执行过程中,因争夺共享资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁。
死锁的几种场景:
忘记释放锁
重复加锁(重复加相同的锁)
多线程多锁,抢占锁资源
//多线程多锁,抢占锁资源#include#include #include // 创建2个互斥量pthread_mutex_t mutex1, mutex2;void * workA(void * arg) { pthread_mutex_lock(&mutex1); sleep(1); pthread_mutex_lock(&mutex2); printf("workA....\n"); pthread_mutex_unlock(&mutex2); pthread_mutex_unlock(&mutex1); return NULL;}void * workB(void * arg) { pthread_mutex_lock(&mutex2); sleep(1); pthread_mutex_lock(&mutex1); printf("workB....\n"); pthread_mutex_unlock(&mutex1); pthread_mutex_unlock(&mutex2); return NULL;}int main() { // 初始化互斥量 pthread_mutex_init(&mutex1, NULL); pthread_mutex_init(&mutex2, NULL); // 创建2个子线程 pthread_t tid1, tid2; pthread_create(&tid1, NULL, workA, NULL); pthread_create(&tid2, NULL, workB, NULL); // 回收子线程资源 pthread_join(tid1, NULL); pthread_join(tid2, NULL); // 释放互斥量资源 pthread_mutex_destroy(&mutex1); pthread_mutex_destroy(&mutex2); return 0;}
执行结果:
读写锁
/* 读写锁的类型 pthread_rwlock_t int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock, const pthread_rwlockattr_t *restrict attr); int pthread_rwlock_destroy(pthread_rwlock_t *rwlock); int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock); int pthread_rwlock_tryrdlock(pthread_rwlock_t *rwlock); int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock); int pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock); int pthread_rwlock_unlock(pthread_rwlock_t *rwlock); 案例:8个线程操作同一个全局变量。 3个线程不定时写这个全局变量,5个线程不定时的读这个全局变量*/#include#include #include // 创建一个共享数据int num = 1;// pthread_mutex_t mutex;pthread_rwlock_t rwlock;void * writeNum(void * arg) { while(1) { pthread_rwlock_wrlock(&rwlock); num++; printf("++write, tid : %ld, num : %d\n", pthread_self(), num); pthread_rwlock_unlock(&rwlock); usleep(100); } return NULL;}void * readNum(void * arg) { while(1) { pthread_rwlock_rdlock(&rwlock); printf("===read, tid : %ld, num : %d\n", pthread_self(), num); pthread_rwlock_unlock(&rwlock); usleep(100); } return NULL;}int main() { pthread_rwlock_init(&rwlock, NULL); // 创建3个写线程,5个读线程 pthread_t wtids[3], rtids[5]; for(int i = 0; i < 3; i++) { pthread_create(&wtids[i], NULL, writeNum, NULL); } for(int i = 0; i < 5; i++) { pthread_create(&rtids[i], NULL, readNum, NULL); } // 设置线程分离 for(int i = 0; i < 3; i++) { pthread_detach(wtids[i]); } for(int i = 0; i < 5; i++) { pthread_detach(rtids[i]); } pthread_exit(NULL); pthread_rwlock_destroy(&rwlock); return 0;}
执行结果:
读时共享,相比互斥锁,提高效率。
以上就是"C语言多线程开发中死锁与读写锁问题怎么解决"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。
线程
死锁
资源
知识
篇文章
不同
两个
全局
变量
语言
问题
开发
共享资源
内容
更多
系统
结果
很大
相同
个子
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全产品品牌对比
u8成本数据库
居民网络安全情况调查
国外全文数据库优点
软件开发服务包括
服务器光纤模块是多模还是单模
http代理服务器 设置
联想st258服务器参数
vf是数据库软件吗
网络安全是黑客吗6
六月网络技术
133软件开发者介绍
征途连接数据库失败
网络安全的主题班会
2019最新网络安全政策
澳大利亚 代理服务器
微信圈子用的什么数据库
亲子网络安全教育感想
即时通讯软件开发难吗
服务器q9300
数据库中的二级映像为
侵犯国家网络安全
多分销软件开发
梦幻西游服务器等级多少天开一级
语音软件开发包
佛山市雅思顿网络技术有限公司
台服wow公会数据库
网络安全电子产品
贵州服务器机柜售后服务
微信圈子用的什么数据库