线程同步——用户模式下线程同步——Slim读写锁实现线程同步
//Slim读/写锁实现线程同步
SRWlock 的目的和关键段相同:对同一资源进行保护,不让其它线程访问。
但是,与关键段不同的是,SRWlock允许我们区分哪些想要读取资源的线程(读取者线程)
和哪些想要更新资源值的线程(写入者线程)。让所有读取者资源在同一时刻访问共享资源应该是
可行的,这是因为仅仅读取资源并不存在破坏数据的风险。只有当写入者线程想要对资源进行更新时才需要同步。
这种情况下,写入者线程应该独占资源访问权:任何线程,无论是读取还是写入者线程,都不许访问资源。
这就是SRWlock强大之处。 //使用步骤:
//(1)必须先定义 CRITICAL_SECTION 结构
SRWLOCK g_cs;
//(2)初始化关键段 SRWLOCK
InitializeSRWLock(&g_cs);
//3)写入者线程
DWORD WINAPI ThreadFunOne(PVOID pvParam)
{
AcquireSRWLockExclusive(&g_cs) ; //写入资源 应该放在AcquireSRWLockExclusive和ReleaseSRWLockExclusive函数之间
g_x ++ ; ReleaseSRWLockExclusive(&g_cs);
return ;
}
//4)读取者线程
DWORD WINAPI ThreadFunTwo(PVOID pvParam)
{
AcquireSRWLockShared(&g_cs) ; //读取资 源应该放在AcquireSRWLockShared和ReleaseSRWLockShared函数之间
cout<<"ThreadFunTwo:"<<g_x<<endl ; ReleaseSRWLockShared(&g_cs);
return ;
} 不存在用来删除或者销毁 SRWLOCK 的函数,因为系统会自动执行清理工作 与关键段相比,SRWlock 缺乏两个特性。
)不存在TryEnter(Shared/Exclusive)SRWLock之类的函数:如果锁已经被占用,
那么调用AcquireSRWLock(Shared/Exclusive)会阻塞调用线程。
)不能递归的获得 SRWLOCK 也就是说一个线程不能多次写入资源而多次锁定资源,
然后多次调用ReleaseSRWLock*来释放资源锁定。 #include "windows.h"
#include "iostream"
using namespace std;
long g_x = ;
//(1)必须先定义 CRITICAL_SECTION 结构
SRWLOCK g_cs; //定义线程函数1
DWORD WINAPI ThreadFunOne(PVOID pvParam) ; //定义线程函数2
DWORD WINAPI ThreadFunTwo(PVOID pvParam); int main()
{ //(2)初始化关键段 SRWLOCK
InitializeSRWLock(&g_cs); //创建线程1
HANDLE hThreadOne = CreateThread(NULL,,ThreadFunOne,,,NULL);
CloseHandle(hThreadOne); //创建线程2
HANDLE hThreadTwo = CreateThread(NULL,,ThreadFunTwo,,,NULL);
CloseHandle(hThreadTwo); //让主线程先挂起,确保其它线程执行完成
Sleep();
cout<<g_x<<endl; //(4)清理CRITICAL_SECTION结构,必须确保已经没有资源使用此关键段,否则会出现不可预料的结果 return ;
} DWORD WINAPI ThreadFunOne(PVOID pvParam)
{
AcquireSRWLockExclusive(&g_cs) ; //写入资源 应该放在AcquireSRWLockExclusive和ReleaseSRWLockExclusive函数之间
g_x ++ ; ReleaseSRWLockExclusive(&g_cs);
return ;
} DWORD WINAPI ThreadFunTwo(PVOID pvParam)
{
AcquireSRWLockShared(&g_cs) ; //读取资 源应该放在AcquireSRWLockShared和ReleaseSRWLockShared函数之间
cout<<"ThreadFunTwo:"<<g_x<<endl ; ReleaseSRWLockShared(&g_cs);
return ;
}
线程同步——用户模式下线程同步——Slim读写锁实现线程同步的更多相关文章
- 线程同步——用户模式下线程同步——Interlocked实现线程同步
线程同步分为用户模式下的线程同步和内核对象的线程同步. 当然用户模式下的线程同步实现速度比内核模式下快,但是功能也有局 //1.利用原子访问: Interlocked系列函数,关于Interlocke ...
- WINDOWS 同步(Interlocked,InterlockedExchangeAdd,Slim读/写锁,WaitForSingleObject,CreateWaitableTimer等等)
NOTE0 在以下两种基本情况下,线程之间需要相互通信: 需要让多个线程同时访问一个共享资源,同时不能破坏资源的完整性: 一个线程需要通知其它线程某项任务已经完成 1.原子访问:Interlocked ...
- Linux:使用读写锁使线程同步
基础与控制原语 读写锁 与互斥量类似,但读写锁允许更高的并行性.其特性为:写独占,读共享. 读写锁状态: 一把读写锁具备三种状态: 1. 读模式下加锁状态 (读锁) 2. 写模式下加锁 ...
- 【windows核心编程】 第八章 用户模式下的线程同步
Windows核心编程 第八章 用户模式下的线程同步 1. 线程之间通信发生在以下两种情况: ① 需要让多个线程同时访问一个共享资源,同时不能破坏资源的完整性 ② 一个线程需要通知其他线程 ...
- 第8章 用户模式下的线程同步(4)_条件变量(Condition Variable)
8.6 条件变量(Condition Variables)——可利用临界区或SRWLock锁来实现 8.6.1 条件变量的使用 (1)条件变量机制就是为了简化 “生产者-消费者”问题而设计的一种线程同 ...
- 第8章 用户模式下的线程同步(3)_Slim读写锁(SRWLock)
8.5 Slim读/写锁(SRWLock)——轻量级的读写锁 (1)SRWLock锁的目的 ①允许读者线程同一时刻访问共享资源(因为不存在破坏数据的风险) ②写者线程应独占资源的访问权,任何其他线程( ...
- windows核心编程---第七章 用户模式下的线程同步
用户模式下的线程同步 系统中的线程必须访问系统资源,如堆.串口.文件.窗口以及其他资源.如果一个线程独占了对某个资源的访问,其他线程就无法完成工作.我们也必须限制线程在任何时刻都能访问任何资源.比如在 ...
- Windows核心编程:第8章 用户模式下的线程同步
Github https://github.com/gongluck/Windows-Core-Program.git //第8章 用户模式下的线程同步.cpp: 定义应用程序的入口点. // #in ...
- 《windows核心编程系列》七谈谈用户模式下的线程同步
用户模式下的线程同步 系统中的线程必须访问系统资源,如堆.串口.文件.窗口以及其他资源.如果一个线程独占了对某个资源的访问,其他线程就无法完成工作.我们也必须限制线程在任何时刻都能访问任何资源.比如在 ...
随机推荐
- can not create symbolic link HDFS解压自动配置lib报错。
如题,使用FusionInsight解压生成样例代码的时候报错,找不到解释.只猜测是权限问题.然后并没有仔细静心思考,心里杂念很多,很浮躁. 解决方法是“以管理员身份运行“. 想想高中:面对问题,不能 ...
- Css预处理器---Less(二)
三.Less语法 (1)变量 //less代码 @nice-blue : #5B83AD; @light-blue : @nice-blue + #111; #header { color : @li ...
- 关于linux下firefox无法播放mp3文件
起因是发现在线翻译的网站没法发音. F12调出console,发现是没法解码mp3文件. 尝试安装deadbeef包,发现安装之后推荐安装的软件列表中有个名为ffmpeg的包.安装上之后,重启fire ...
- 记在Archlinux中安装python的pymssql模块过程中遇到的问题
为什么要安装这个模块?因为要连接SQLServer数据库. 看到可以使用pyodbc这个模块进行连接,但对odbc不熟悉,所以选用了看起来更简单的 pymssql. 直接执行: pip install ...
- Unity3d之如何截屏
Unity3d中有时有截屏的需求,那如何截屏呢,代码如下: /// <summary> /// 截屏 /// </summary> /// <param name=&qu ...
- object base基类分析
uvm_object,是所有uvm data和hierarchical class的基类,实现了copy,compare,print,record之类的函数 扩展类中必须实现create和get_ty ...
- 水题 J
一张CT扫描的灰度图像可以用一个N*N(0 < N <= 100)的矩阵描述,矩阵上的每个点对应一个灰度值(整数),其取值范围是0-255.我们假设给定的图像中有且只有一个肿瘤.在图上监测 ...
- MOG插件(葡萄牙语,略作翻译)
这次记录下MOG大神的插件,自从我发现了这个插件,似乎开启了一个新世界诶~~~ 网址 https://atelierrgss.wordpress.com 1. MOG_YuruYuri.js CARA ...
- How to compute f1 score for each epoch in Keras
https://medium.com/@thongonary/how-to-compute-f1-score-for-each-epoch-in-keras-a1acd17715a2 https:// ...
- oracle 排序 row_number() over(partition by 排序字段)
业务描述:按t.truckId,t.riskCode 分组,每个分组里有分数,取分组中分数最大的那条记录. 如:A1 B1 5 6 A1 B1 5 3 A1 B2 2 5 A1 ...