linux多线程之嵌套锁技术
来源:互联网 发布:淘宝活动说明范文 编辑:程序博客网 时间:2024/04/29 21:16
嵌套锁这个概念,主要是为了根据编程中的一种情形引申出来的。什么情况呢,我们可以具体说明一下。假设你在处理一个公共函数的时候,因为中间涉及公共数据,所以你加了一个锁。但是,有一点比较悲哀。这个公共函数自身也加了一个锁,而且和你加的锁是一样的。所以,除非你的使用的是信号量,要不然你的程序一辈子也获取不了这个锁。
- HANDLE hLock;
- void sub_func()
- {
- /*...*/
- WaitForSingleObject(hLock, INFINITE);
- do_something();
- ReleaseMutex(hLock);
- /*...*/
- }
- void data_process()
- {
- /*...*/
- WaitForSingleObject(hLock, INFINITE);
- sub_func();
- ReleaseMutex(hLock);
- /*...*/
- }
HANDLE hLock;void sub_func(){ /*...*/ WaitForSingleObject(hLock, INFINITE); do_something(); ReleaseMutex(hLock); /*...*/}void data_process(){ /*...*/ WaitForSingleObject(hLock, INFINITE); sub_func(); ReleaseMutex(hLock); /*...*/}出现这种情况的原因很多。很重要的一个方面是因为软件的各个模块是不同的人负责的。所以本质上说,我们根本无法确定别人使用了什么样的锁。你也无权不让别人使用某个锁。所以,遇到这种情况,只好靠你自己了。嵌套锁就是不错的一个解决办法。
(1)嵌套锁的数据结构
- typedef struct _NestLock
- {
- int threadId;
- int count;
- HANDLE hLock;
- }NestLock;
- NestLock* create_nest_lock(HANLDE hLock)
- {
- NestLock* hNestLock = (NestLock*)malloc(sizeof(NestLock));
- assert(NULL != hNestLock);
- hNestLock->threadId = hNestLock->count = 0;
- hNestLock->hLock = hLock;
- return hNestLock;
- }
typedef struct _NestLock{ int threadId; int count; HANDLE hLock;}NestLock;NestLock* create_nest_lock(HANLDE hLock){ NestLock* hNestLock = (NestLock*)malloc(sizeof(NestLock)); assert(NULL != hNestLock); hNestLock->threadId = hNestLock->count = 0; hNestLock->hLock = hLock; return hNestLock;}
(2)申请嵌套锁
- void get_nest_lock(NestLock* hNestLock)
- {
- assert(NULL != hNestLock);
- if(hNestLock->threadId == GetThreadId())
- {
- hNestLock->count ++;
- }else{
- WaitForSingleObject(hNestLock->hLock);
- hNestLock->count = 1;
- hNestLock->threadId = GetThreadId();
- }
- }
void get_nest_lock(NestLock* hNestLock){ assert(NULL != hNestLock); if(hNestLock->threadId == GetThreadId()) { hNestLock->count ++; }else{ WaitForSingleObject(hNestLock->hLock); hNestLock->count = 1; hNestLock->threadId = GetThreadId(); }}
(3)释放锁
- void release_nest_lock(NestLock* hNestLock)
- {
- assert(NULL != hNestLock);
- assert(GetThreadId() == hNestLock->threadId);
- hNestLock->count --;
- if(0 == hNestLock->count){
- hNestLock->threadId = 0;
- ReleaseMutex(hNestLock->hLock);
- }
- }
void release_nest_lock(NestLock* hNestLock){ assert(NULL != hNestLock); assert(GetThreadId() == hNestLock->threadId); hNestLock->count --; if(0 == hNestLock->count){ hNestLock->threadId = 0; ReleaseMutex(hNestLock->hLock); }}
文章总结:
(1)嵌套锁与其说是新的锁类型,不如说是统计锁而已
(2)嵌套锁和普通的锁一样,使用十分方便
(3)嵌套锁也有缺点,它给我们的锁检测带来了麻烦
- linux多线程之嵌套锁技术
- linux 多线程之顺序锁技术
- linux多线程之原子锁技术
- linux多线程之自旋锁技术
- 多线程----嵌套锁
- 多线程的嵌套锁
- 多线程的那点儿事(之嵌套锁)
- 多线程的那点儿事(之嵌套锁)
- 多线程的那点儿事(之嵌套锁)
- 多线程的那点儿事(之嵌套锁)
- Linux多线程技术总结
- 多线程技术----最简单的demo开始之linux版
- linux多线程之读写锁
- linux多线程之自旋锁
- linux多线程之读写锁
- linux之读写锁技术
- LInux多线程编程技术总结
- Linux多线程编程技术总结
- mysql 自动备份
- Lady Greensleeves
- 一个简单的企业进销存管理系统 .
- Ubuntu MYSQL环境搭建(apt-get install方式)
- nm用来列出目标文件(静动态库)的符号清单 也相当windows的depends
- linux多线程之嵌套锁技术
- 【jeecg-mybatis版本】 mybatis+spring mvc 完美整合方案 查询,保存,更新,删除自动生成
- 我们一起学网络(七)——网络层(路由选择协议)
- 只能输入数字和小数点
- CKEditor去掉默认的<p>的处理
- iOS 7 iPhone iPad应用开发技术详解
- Unity3d Web Player 的server端联网配置
- 实现设备只能被一个进程打开
- Android 开发常用命令