RW锁 读写锁,也叫共享独占锁 
互斥量 要么是锁住状态,要么是不加锁状态,而且一次只有一个线程可以对其加锁。

读写锁可以有三种状态,读模式下加锁状态,写模式下加锁状态,不加锁状态。一次只有一个线程可以占有写模式的读写锁,但是多个线程可以同时占有读模式的读写锁。

和互斥量一样,读写锁在使用之前必须初始化,在释放他们底层的内存前必须销毁。

要在读模式下锁定读写锁,需要调用pthread_rwlock_rdlock; 
要在写模式下锁定读写锁,需要调用pthread_rwlock_wrlock; 
不管以何种方式锁住读写锁,都可以调用pthread_rwlock_unlock 进行解锁。

在读操作远远高于写操作的时候,使用读写锁才可能改善性能。

下面给出一个cpp 版本的 rw_lock

Rwlock.h

<code class="hljs cs has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">class RwLock {NOCOPY_CLASS(RwLock);<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">public</span>:<span class="hljs-title" style="box-sizing: border-box;">RwLock</span>();<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">virtual</span> ~RwLock();<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> ReadLock();<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> WriteLock();<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> Unlock();<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> ReadUnlock();<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> WriteUnlock();<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">bool</span> IsReadLocked();<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">bool</span> IsWriteLocked();<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">private</span>:pthread_rwlock_t lock_;
};Rw_lock.cc</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li><li style="box-sizing: border-box; padding: 0px 5px;">12</li><li style="box-sizing: border-box; padding: 0px 5px;">13</li><li style="box-sizing: border-box; padding: 0px 5px;">14</li><li style="box-sizing: border-box; padding: 0px 5px;">15</li><li style="box-sizing: border-box; padding: 0px 5px;">16</li><li style="box-sizing: border-box; padding: 0px 5px;">17</li><li style="box-sizing: border-box; padding: 0px 5px;">18</li><li style="box-sizing: border-box; padding: 0px 5px;">19</li><li style="box-sizing: border-box; padding: 0px 5px;">20</li></ul><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li><li style="box-sizing: border-box; padding: 0px 5px;">12</li><li style="box-sizing: border-box; padding: 0px 5px;">13</li><li style="box-sizing: border-box; padding: 0px 5px;">14</li><li style="box-sizing: border-box; padding: 0px 5px;">15</li><li style="box-sizing: border-box; padding: 0px 5px;">16</li><li style="box-sizing: border-box; padding: 0px 5px;">17</li><li style="box-sizing: border-box; padding: 0px 5px;">18</li><li style="box-sizing: border-box; padding: 0px 5px;">19</li><li style="box-sizing: border-box; padding: 0px 5px;">20</li></ul>
<code class="hljs d has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">RwLock::RwLock() {pthread_rwlock_init(&lock_, <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">0</span>);
}RwLock::~RwLock() {pthread_rwlock_destroy(&lock_);
}<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> RwLock::ReadLock() {pthread_rwlock_rdlock(&lock_);
}<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> RwLock::WriteLock() {pthread_rwlock_wrlock(&lock_);
}<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> RwLock::Unlock() {<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">assert</span>(IsReadLocked() || IsWriteLocked());pthread_rwlock_unlock(&lock_);
}<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> RwLock::ReadUnlock() {<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">assert</span>(IsReadLocked());pthread_rwlock_unlock(&lock_);
}<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> RwLock::WriteUnlock() {<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">assert</span>(IsWriteLocked());pthread_rwlock_unlock(&lock_);
}<span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">bool</span> RwLock::IsReadLocked() {<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">return</span> lock_.__data.__nr_readers != <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">0</span>;
}<span class="hljs-built_in" style="color: rgb(102, 0, 102); box-sizing: border-box;">bool</span> RwLock::IsWriteLocked() {<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">return</span> lock_.__data.__writer != <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">0</span>;
}</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li><li style="box-sizing: border-box; padding: 0px 5px;">12</li><li style="box-sizing: border-box; padding: 0px 5px;">13</li><li style="box-sizing: border-box; padding: 0px 5px;">14</li><li style="box-sizing: border-box; padding: 0px 5px;">15</li><li style="box-sizing: border-box; padding: 0px 5px;">16</li><li style="box-sizing: border-box; padding: 0px 5px;">17</li><li style="box-sizing: border-box; padding: 0px 5px;">18</li><li style="box-sizing: border-box; padding: 0px 5px;">19</li><li style="box-sizing: border-box; padding: 0px 5px;">20</li><li style="box-sizing: border-box; padding: 0px 5px;">21</li><li style="box-sizing: border-box; padding: 0px 5px;">22</li><li style="box-sizing: border-box; padding: 0px 5px;">23</li><li style="box-sizing: border-box; padding: 0px 5px;">24</li><li style="box-sizing: border-box; padding: 0px 5px;">25</li><li style="box-sizing: border-box; padding: 0px 5px;">26</li><li style="box-sizing: border-box; padding: 0px 5px;">27</li><li style="box-sizing: border-box; padding: 0px 5px;">28</li><li style="box-sizing: border-box; padding: 0px 5px;">29</li><li style="box-sizing: border-box; padding: 0px 5px;">30</li><li style="box-sizing: border-box; padding: 0px 5px;">31</li><li style="box-sizing: border-box; padding: 0px 5px;">32</li><li style="box-sizing: border-box; padding: 0px 5px;">33</li><li style="box-sizing: border-box; padding: 0px 5px;">34</li><li style="box-sizing: border-box; padding: 0px 5px;">35</li><li style="box-sizing: border-box; padding: 0px 5px;">36</li><li style="box-sizing: border-box; padding: 0px 5px;">37</li><li style="box-sizing: border-box; padding: 0px 5px;">38</li></ul><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li><li style="box-sizing: border-box; padding: 0px 5px;">12</li><li style="box-sizing: border-box; padding: 0px 5px;">13</li><li style="box-sizing: border-box; padding: 0px 5px;">14</li><li style="box-sizing: border-box; padding: 0px 5px;">15</li><li style="box-sizing: border-box; padding: 0px 5px;">16</li><li style="box-sizing: border-box; padding: 0px 5px;">17</li><li style="box-sizing: border-box; padding: 0px 5px;">18</li><li style="box-sizing: border-box; padding: 0px 5px;">19</li><li style="box-sizing: border-box; padding: 0px 5px;">20</li><li style="box-sizing: border-box; padding: 0px 5px;">21</li><li style="box-sizing: border-box; padding: 0px 5px;">22</li><li style="box-sizing: border-box; padding: 0px 5px;">23</li><li style="box-sizing: border-box; padding: 0px 5px;">24</li><li style="box-sizing: border-box; padding: 0px 5px;">25</li><li style="box-sizing: border-box; padding: 0px 5px;">26</li><li style="box-sizing: border-box; padding: 0px 5px;">27</li><li style="box-sizing: border-box; padding: 0px 5px;">28</li><li style="box-sizing: border-box; padding: 0px 5px;">29</li><li style="box-sizing: border-box; padding: 0px 5px;">30</li><li style="box-sizing: border-box; padding: 0px 5px;">31</li><li style="box-sizing: border-box; padding: 0px 5px;">32</li><li style="box-sizing: border-box; padding: 0px 5px;">33</li><li style="box-sizing: border-box; padding: 0px 5px;">34</li><li style="box-sizing: border-box; padding: 0px 5px;">35</li><li style="box-sizing: border-box; padding: 0px 5px;">36</li><li style="box-sizing: border-box; padding: 0px 5px;">37</li><li style="box-sizing: border-box; padding: 0px 5px;">38</li></ul>

同样,不建议直接使用成员函数来上锁,需要写一个ReadLockGuard模版来更好的使用锁,防止出错。

<code class="hljs haskell has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-title" style="box-sizing: border-box;">template</span> <typename <span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">LockTye</span>>
<span class="hljs-class" style="box-sizing: border-box;"><span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">class</span> <span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">ReadLockGuard</span> {<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">NOCOPY_CLASS</span><span class="hljs-container" style="box-sizing: border-box;">(<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">ReadLockGuard</span>)</span>;public:<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">ReadLockGuard</span><span class="hljs-container" style="box-sizing: border-box;">(<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">LockType</span> * <span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">lock</span>)</span>:lock_<span class="hljs-container" style="box-sizing: border-box;">(<span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">lock</span>)</span> {lock-><span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">ReadLock</span><span class="hljs-container" style="box-sizing: border-box;">()</span>;}~<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">ReadLockGuard</span><span class="hljs-container" style="box-sizing: border-box;">()</span> {lock_-><span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">ReadUnlock</span><span class="hljs-container" style="box-sizing: border-box;">()</span>;}private:<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">LockType</span>* lock_;
};template <typename <span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">LockType</span>>
<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">class</span> <span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">WriteLockGuard</span> {<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">NOCOPY_CLASS</span><span class="hljs-container" style="box-sizing: border-box;">(<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">WriteLockGuard</span>)</span>;public:<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">WriteLockGuard</span><span class="hljs-container" style="box-sizing: border-box;">(<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">LockType</span>* <span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">lock</span>)</span>: lock_<span class="hljs-container" style="box-sizing: border-box;">(<span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">lock</span>)</span> {lock_-><span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">WriteLock</span><span class="hljs-container" style="box-sizing: border-box;">()</span>;}~<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">WriteLockGuard</span><span class="hljs-container" style="box-sizing: border-box;">()</span> {lock_-><span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">WriteUnlock</span><span class="hljs-container" style="box-sizing: border-box;">()</span>;}private:<span class="hljs-type" style="box-sizing: border-box; color: rgb(102, 0, 102);">LockType</span>* lock_;
};</span></code>

多线程编程 RW_LOCK 读写锁相关推荐

  1. Java多线程编程之读写锁【ReentrantReadWriteLock】

    有时候我们需要有这样的需求:         对于同一个文件进行读和写操作,普通的锁是互斥的,这样读的时候会加锁,只能单线程的读,我们希望多线程的进行读操作,并且读的时候不能进行写操作,写的时候不能进 ...

  2. Linux多线程的同步------读写锁

    前面介绍过Linux多线程同步的另外两个方法------互斥锁和信号量 Linux多线程的同步-----信号量和互斥锁_神厨小福贵!的博客-CSDN博客 下面来看一下读写锁: 读写锁和互斥锁都带有一个 ...

  3. Java Review - 并发编程_读写锁ReentrantReadWriteLock的原理源码剖析

    文章目录 ReentrantLock VS ReentrantReadWriteLock 类图结构 非公平的读写锁实现 写锁的获取与释放 void lock() void lockInterrupti ...

  4. Java并发编程-ReadWriteLock读写锁

    1.ReadWriteLock介绍 为什么我们有了Lock,还要用ReadWriteLock呢.我们对共享资源加锁之后,所有的线程都将会等待.Lock读操作也锁,写操作也会锁,而对共享资源读的时候,其 ...

  5. 多线程并发之读写锁(ReentranReadWriteLockReadWriteLock)使用详解

    [1]基本讲解与使用 ① ReadWriteLock同Lock一样也是一个接口,提供了readLock和writeLock两种锁的操作机制,一个是只读的锁,一个是写锁. 读锁可以在没有写锁的时候被多个 ...

  6. Java 并发编程之读写锁 ReentrantReadWriteLock

    ReentrantReadWriteLock 允许多个读操作同时进行,但是只允许一个写操作同时进行,在某些情况下,可以实现更高的并发性. 举个栗子: public class ReadAndWrite ...

  7. 【C/C++多线程编程之九】pthread读写锁

    多线程编程之读写锁 Pthread是 POSIX threads 的简称,是POSIX的线程标准. pthread读写锁把对共享资源的访问者分为读者和写者,读者只对共享资源进行读访问,写者只对共享资源 ...

  8. java车次信息_从火车站车次公示栏来学Java读写锁

    Java多线程并发之读写锁 本文主要内容:读写锁的理论:通过生活中例子来理解读写锁:读写锁的代码演示:读写锁总结.通过理论(总结)-例子-代码-然后再次总结,这四个步骤来让大家对读写锁的深刻理解. 本 ...

  9. java写车次查询_从火车站车次公示栏来学Java读写锁

    Java多线程并发之读写锁 本文主要内容:读写锁的理论:通过生活中例子来理解读写锁:读写锁的代码演示:读写锁总结.通过理论(总结)-例子-代码-然后再次总结,这四个步骤来让大家对读写锁的深刻理解. 本 ...

最新文章

  1. ReentrantLock可重入锁的使用场景(转)
  2. python字符串切片用法_详解Python字符串切片
  3. 怎么解决python Non-ASCII character错误
  4. 工作112:vue路由跳转错误:Error: Redirected when going from “/login“ to “/home“ via a navigation guard.
  5. ssh xm 工具_比较一下几款常用的SSH工具
  6. linux下chkConfig的用法,mysqld开机自启动
  7. EMD算法原理分解信号
  8. 109. 有序链表转换二叉搜索树
  9. Relaxation step(Dijkstra's 最短路径算法)
  10. VBA实战技巧精粹之按某列相同数据分入同一个sheet
  11. python比对excel表数据中的差异_Python比对EXCEL数据
  12. 【历史上的今天】7 月 1 日:分时系统之父诞生;支付宝推出条码支付;世界上第一支电视广告
  13. How long is the way to the Architect?
  14. 想要好看的设计?收下这份网页背景设计指南吧!
  15. 安装mathtype6.9时显示缺少MT Extra字体问题
  16. 重置 winsocks
  17. CF1151F Sonya and Informatics
  18. Mac OS安装NS 3
  19. 跨域错误的原因及处理方法
  20. 从0开始集成Spring和mybatis

热门文章

  1. linux (阿里云 CentOS7) 中安装配置 RocketMQ
  2. 解决:A component required a bean of type ‘javax.jms.Queue‘ that could not be found.
  3. Asp.Net MVC 页面代码压缩筛选器-自定义删除无效内容
  4. 如何实现动态水球图 --》 echars结合echarts-liquidfill实现
  5. android node
  6. C#题目及答案(1)
  7. 阿里云Https部署网站
  8. CentOS7安装Hadoop2.7完整步骤
  9. 【原创】StreamInsight查询系列(三)——基本查询操作之过滤
  10. 一卡通vip充值消费线上oracle库服务器故障排查过程