C++临界区LockCount的定义。
第一部分得出的结果表示临界区是否为释放,0为已锁定,1位已释放
0:009> ? 0x1 & (-0n22) :前面0:009> ?不用管,只需要理解后面部分意思就是-22和1按位做与运算
第二部分得出的结果表示临界区是否被线程所拥有,0表示是,1表示否
0:009> ? (0x2 & (-0n22)) >>1 :前面0:009> ?不用管,只需要理解后面部分意思是-22和2按位做与运算后按位右移一位
第三部分表示有多少个线程正在等待临界区,注意是等待,不包括已进入临界区的,所以要从Enter开始计数后检1才是该值
0:009> ? ((-1) & (-0n22)) >>2 :前面0:009> ?不用管,只需要理解后面部分意思是-1减去-22后右移两位
本文详细解析了C++中临界区LockCount的定义及使用方式,包括如何判断临界区是否释放、是否被线程拥有,以及有多少线程正在等待临界区。通过对LockCount的深入理解,有助于提升多线程编程技能。
1万+

被折叠的 条评论
为什么被折叠?



