//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读写锁实现线程同步的更多相关文章

  1. 线程同步——用户模式下线程同步——Interlocked实现线程同步

    线程同步分为用户模式下的线程同步和内核对象的线程同步. 当然用户模式下的线程同步实现速度比内核模式下快,但是功能也有局 //1.利用原子访问: Interlocked系列函数,关于Interlocke ...

  2. WINDOWS 同步(Interlocked,InterlockedExchangeAdd,Slim读/写锁,WaitForSingleObject,CreateWaitableTimer等等)

    NOTE0 在以下两种基本情况下,线程之间需要相互通信: 需要让多个线程同时访问一个共享资源,同时不能破坏资源的完整性: 一个线程需要通知其它线程某项任务已经完成 1.原子访问:Interlocked ...

  3. Linux:使用读写锁使线程同步

    基础与控制原语 读写锁 与互斥量类似,但读写锁允许更高的并行性.其特性为:写独占,读共享. 读写锁状态: 一把读写锁具备三种状态:     1. 读模式下加锁状态 (读锁)     2. 写模式下加锁 ...

  4. 【windows核心编程】 第八章 用户模式下的线程同步

    Windows核心编程 第八章 用户模式下的线程同步 1. 线程之间通信发生在以下两种情况: ①    需要让多个线程同时访问一个共享资源,同时不能破坏资源的完整性 ②    一个线程需要通知其他线程 ...

  5. 第8章 用户模式下的线程同步(4)_条件变量(Condition Variable)

    8.6 条件变量(Condition Variables)——可利用临界区或SRWLock锁来实现 8.6.1 条件变量的使用 (1)条件变量机制就是为了简化 “生产者-消费者”问题而设计的一种线程同 ...

  6. 第8章 用户模式下的线程同步(3)_Slim读写锁(SRWLock)

    8.5 Slim读/写锁(SRWLock)——轻量级的读写锁 (1)SRWLock锁的目的 ①允许读者线程同一时刻访问共享资源(因为不存在破坏数据的风险) ②写者线程应独占资源的访问权,任何其他线程( ...

  7. windows核心编程---第七章 用户模式下的线程同步

    用户模式下的线程同步 系统中的线程必须访问系统资源,如堆.串口.文件.窗口以及其他资源.如果一个线程独占了对某个资源的访问,其他线程就无法完成工作.我们也必须限制线程在任何时刻都能访问任何资源.比如在 ...

  8. Windows核心编程:第8章 用户模式下的线程同步

    Github https://github.com/gongluck/Windows-Core-Program.git //第8章 用户模式下的线程同步.cpp: 定义应用程序的入口点. // #in ...

  9. 《windows核心编程系列》七谈谈用户模式下的线程同步

    用户模式下的线程同步 系统中的线程必须访问系统资源,如堆.串口.文件.窗口以及其他资源.如果一个线程独占了对某个资源的访问,其他线程就无法完成工作.我们也必须限制线程在任何时刻都能访问任何资源.比如在 ...

随机推荐

  1. Linux性能优化gprof使用

    gprof用于分析函数调用耗时,可用之抓出最耗时的函数,以便优化程序. gcc链接时也一定要加-pg参数,以使程序运行结束后生成gmon.out文件,供gprof分析. gprof默认不支持多线程程序 ...

  2. centos7及服务器端安装python2.7.13, setuptools, pip

    1. 安装python2.7.13 因为涉及到安装到服务器,所以可能不能直接在usr/bin及usr/local/bin下安装,所以本文详解安装在自定义目录下. 下载安装包: $ wget https ...

  3. 例子:动能并不是特别强(2-3)后,下M5的同时,也是恢复期到期的前一天

    动能并不是特别强(2-3)后,下M5的同时,但是恢复期到期 EG.002195 2017/06/23-->2017/06/29

  4. BCB6.0 清除TPanel面板上的所有控件

    方法一: panel->ComponentCount属性获得panel所拥有的控件个数 panel->Components[i]属性获得某一个控件 delete panel->Com ...

  5. D Cloud of Hashtags Codeforces Round #401 (Div. 2)

    Cloud of Hashtags [题目链接]Cloud of Hashtags &题意: 给你一个n,之后给出n个串,这些串的总长度不超过5e5,你要删除最少的单词(并且只能是后缀),使得 ...

  6. 关于hibernate总是报错 配置factory的id找不到,mapping配置文件Could not parse mapping document from input stream

    Caused by: org.hibernate.InvalidMappingException: Could not parse mapping document from input stream ...

  7. oracle数据库数值类型

    ---恢复内容开始--- 内容摘自网络 Oracle的数值类型有int,number,float,decimal,numberic等. NUMBER类型   定义   定义格式NUMBER (prec ...

  8. 17. Letter Combinations of a Phone Number(bfs)

    Given a string containing digits from 2-9 inclusive, return all possible letter combinations that th ...

  9. mysql分区/分片

    一.分区概念 mysql 5.1 以后支持分区, 有点类似MongoDB中的分片概念. 就是按照一定的规则, 将一个数据库表分解成很多细小的表, 这些细小的表可以是物理的分区, 就是在不同的位置. 但 ...

  10. FileInputstream,FileOutputstream 和 byteArrayInputStream,byteArrayOutputStream

    你知道FileInputstream和FileOutputstream吗?FileInputstream,FileOutputstream分别是由抽象类Inputstream和Outputstream ...