基础与控制原语

读写锁

与互斥量类似,但读写锁允许更高的并行性。其特性为:写独占,读共享。

读写锁状态:

一把读写锁具备三种状态:

1. 读模式下加锁状态 (读锁)

2. 写模式下加锁状态 (写锁)

3. 不加锁状态

读写锁特性:

读写锁是"写模式加锁"时, 解锁前,所有对该锁加锁的线程都会被阻塞。

读写锁是"读模式加锁"时, 如果线程以读模式对其加锁会成功;如果线程以写模式加锁会阻塞。

读写锁是"读模式加锁"时, 既有试图以写模式加锁的线程,也有试图以读模式加锁的线程。那么读写锁会阻塞随后的读模式锁请求。优先满足写模式锁。读锁、写锁并行阻塞,写锁优先级高

读写锁也叫共享-独占锁。当读写锁以读模式锁住时,它是以共享模式锁住的;当它以写模式锁住时,它是以独占模式锁住的。写独占、读共享。

读写锁非常适合于对数据结构读的次数远大于写的情况。

主要应用函数:

pthread_rwlock_init函数

pthread_rwlock_destroy函数

pthread_rwlock_rdlock函数

pthread_rwlock_wrlock函数

pthread_rwlock_tryrdlock函数

pthread_rwlock_trywrlock函数

pthread_rwlock_unlock函数

以上7 个函数的返回值都是:成功返回0, 失败直接返回错误号。

pthread_rwlock_t类型    用于定义一个读写锁变量。

pthread_rwlock_t rwlock;

pthread_rwlock_init函数

初始化一把读写锁

int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock, const pthread_rwlockattr_t *restrict attr);

参2:attr表读写锁属性,通常使用默认属性,传NULL即可。

pthread_rwlock_destroy函数

销毁一把读写锁

int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);

pthread_rwlock_rdlock函数

以读方式请求读写锁。(常简称为:请求读锁)

int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock);

pthread_rwlock_wrlock函数

以写方式请求读写锁。(常简称为:请求写锁)

int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock);

pthread_rwlock_unlock函数

解锁

int pthread_rwlock_unlock(pthread_rwlock_t *rwlock);

pthread_rwlock_tryrdlock函数

非阻塞以读方式请求读写锁(非阻塞请求读锁)

int pthread_rwlock_tryrdlock(pthread_rwlock_t *rwlock);

pthread_rwlock_trywrlock函数

非阻塞以写方式请求读写锁(非阻塞请求写锁)

int pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock);

读写锁示例

看如下示例,同时有多个线程对同一全局数据读、写操作。

#include

#include

#include

#include

pthread_rwlock_t rwlock;

long

int love;

void *pth_wr(void *arg)

{

int i = (int)arg;

while (love <= 520)

{

pthread_rwlock_wrlock(&rwlock);//请求写锁

printf("write================全局变量love = %ld, 我是%d号线程。\n", love += 40, i + 1);

pthread_rwlock_unlock(&rwlock);//解锁

sleep(1);

}

return

NULL;

}

void *pth_rd(void *arg)

{

int i = (int)arg;

while (love <= 520)

{

pthread_rwlock_rdlock(&rwlock);//请求读锁

printf("全局变量love = %ld, 我是%d号线程。————— - read\n", love, i + 1);

pthread_rwlock_unlock(&rwlock);//解锁

sleep(1);

}

return

NULL;

}

int main(void)

{

pthread_t pth[10];

int i;

pthread_rwlock_init(&rwlock, NULL);

for (i = 0; i != 5; i++)//写

{

pthread_create(&pth[i], NULL, pth_wr, (void *)i);

}

for (i = 0; i != 5; i++)//读

{

pthread_create(&pth[5 + i], NULL, pth_rd, (void *)i);

}

while (1)

{

if (love >= 520)

{

for (int j = 0; j != 10; j++)

{

pthread_cancel(pth[j]);//杀死线程

pthread_join(pth[j], NULL);//回收线程

}

break;

}

}

return 0;

}

在里面,定义了一个全局变量love,当love大于520的时候就停止读写并杀死回收线程。读写锁加解锁的位置和互斥量加解锁的位置一样,直接看结果吧:

看,读数据的时候时一致的,并且读出来的数据与前面写进去的数据保持一致,并没有出现读出的数据和写入的数据不一致的情况。虽然线程执行顺序没有顺序,但是这并不重要,这只是内核调度和线程争夺资源的结果,我们关心的不是线程执行顺序,而是结果。很明显,加了锁之后整整齐齐,是我们想要的效果;当然这样写在64位上编译的时候会有警告:

原因我在上一篇博客上说了的,这里不再做解释。

现在我们来看看不加锁的情况,代码就是把那些锁去掉就是。

这是每次加40的结果;

这是每次加20的结果,可以看到,次数越多,混乱的情况就越严重。

线程同步——用户模式下线程同步——Slim读写锁实现线程同步

//Slim读/写锁实现线程同步 SRWlock 的目的和关键段相同:对同一资源进行保护,不让其它线程访问. 但是,与关键段不同的是,SRWlock允许我们区分哪些想要读取资源的线程(读取者线程) 和 ...

linux使用读写锁pthread&lowbar;rwlock&lowbar;t

转自:http://blog.csdn.net/onlyou930/article/details/6755593 使用读写锁 配置读写锁的属性之后,即可初始化读写锁.以下函数用于初始化或销毁读写锁. ...

linux中读写锁的rwlock介绍-nk&lowbar;ysg-ChinaUnix博客

linux中读写锁的rwlock介绍-nk_ysg-ChinaUnix博客 linux中读写锁的rwlock介绍 2013-02-26 13:59:35 分类: C/C++   http://yaro ...

Linux多线程编程——多线程与线程同步

多线程 使用多线程好处: 一.通过为每种事件类型的处理单独分配线程,可以简化处理异步事件的代码,线程处理事件可以采用同步编程模式,启闭异步编程模式简单 二.方便的通信和数据交换 由于进程之间具有独立的 ...

读-写锁 ReadWriteLock &amp&semi; 线程八锁

读-写锁 ReadWriteLock: ①ReadWriteLock 维护了一对相关的锁,一个用于只读操作, 另一个用于写入操作. 只要没有 writer,读取锁可以由 多个 reader 线程同时保 ...

linux 一个读写锁的异常导致的故障

环境信息: WARNING: kernel version inconsistency between vmlinux and dumpfile KERNEL: vmlinux-47.90 DUMPF ...

java读写锁实现数据同步访问

锁机制最大的改进之一就是ReadWriteLock接口和它的唯一实现类ReentrantReadWriteLock.这个类有两个锁,一个是读操作锁,另一个是写操作锁.使用读操作锁时可以允许多个线程同时 ...

【Linux】Mutex互斥量线程同步的例子

0.互斥量  Windows下的互斥量 是个内核对象,每次WaitForSingleObject和ReleaseMutex时都会检查当前线程ID和占有互斥量的线程ID是否一致. 当多次Wait**时就 ...

笔记2 linux多线程 读写锁

//read write lock #include #include #include struct ...

随机推荐

Trie tree实践

1.Trie树 Trie树即字典树或前缀树, 2.实践 代码实践如下: package cn.edu.buaa.trie; import java.util.HashSet; /** * @autho ...

DataGridView的单元格控制只能输入数字

主要是应用DataGridView的EditingControlShowing事件.当单元格进入编辑模式时,可以处理执行该编辑控件的自定义初始化的此事件. public DataGridViewTex ...

渐进式jpeg&lpar;progressive jpeg&rpar;图片及其相关 --图片的两种加载方式

渐进式jpeg(progressive jpeg)图片及其相关   一.基本JPEG(baseline jpeg)和渐进JPEG 网络上那些色色的照片都是.jpg格式的("色色"指 ...

KVO的概述的使用

一,概述 KVO,即:Key-Value Observing,它提供一种机制,当指定的对象的属性被修改后,则对象就会接受到通知.简单的说就是每次指定的被观察的对象的属性被修改后,KVO就会自动通知相应 ...

C&num; for循环①护栏长度 ②广场砖面积 ③判断闰年平年

// static void Main(string[] args)         { const double PI = 3.14;             const int BAR_U ...

asp&period;net textbox控件readonly为true时,后台取值的问题

如题,在后台通过textbox.Text方式取值为空,不论你默认值是否是空,如想要获得,需通过request.Form[""]的方式.

错误:Unsupported major&period;minor version 51&period;0的解决

问题: 在电脑上双击打开一个可执行的jar时报错:Unsupported major.minor version 51.0.原因是版本问题,该jar使用jdk1.7编译,而我电脑装的是jdk1.6. ...

NoHttp封装--03 cookie

NoHttp请求自动维持Cookie:   1.支持Session.Cookie.临时Cookie的位置.   2.支持App重启.关机开机后继续持久化维持.   3.提供了接口,允许开发者监听Coo ...

手动编译安装lamp之php

转自马哥教育讲课文档 三.编译安装php-5.4.8 1.解决依赖关系: 请配置好yum源(可以是本地系统光盘)后执行如下命令: # yum -y groupinstall "X Softw ...

GUC-2 原子性

import java.util.concurrent.atomic.AtomicInteger; /* * 一.i++ 的原子性问题:i++ 的操作实际上分为三个步骤“读-改-写” * int i ...

linux读和写线程同步,Linux:使用读写锁使线程同步相关推荐

  1. php打开文件读和写,PHP实现文件的读和写功能

    PHP实现文件的读和写功能 进行文件的读和写,先打开一个文件,然后开始读或者写文件,最后再关系这个文件资源. 如,文件的读操作: $file = fopen('your file path','r') ...

  2. linux脚本里写进入根目录,Linux重要目录、部分命令及权限

    (Linux下vim的配置,及g++.gdb的安装:http://blog.csdn.net/qq_34021920/article/details/76376837) 一.Linux下根目录的文件 ...

  3. am335x linux内核烧写_实时 Linux 抖动分析 Step by step

    本文首次发表于 实时 Linux 抖动分析 Step by step 前段时间有同学问到: 大家有显卡方面实时性调优经验交流吗?我现在是 x86,不加显示任务实时性可以保持在 20us 内,如果加上显 ...

  4. linux查看程序写文件内容,Linux 文件内容查看命令

    Linux系统中使用以下命令来查看文件的内容: cat  由第一行开始显示文件内容 tac  从最后一行开始显示,可以看出 tac 是 cat 的倒著写! nl   显示的时候,顺道输出行号! mor ...

  5. linux用vi写文件内容,Linux下利用vi编辑器创建文件并写入内容 专家详解

    Linux系统作为一款以命令行操作为主的系统,vi编辑器无疑大大扩展了命令行的功能,使用户在命令行下可以进行文件的各种操作,学会vi编辑器的使用无疑是非常必要的.而且vi的使用和vim的使用非常相似, ...

  6. linux给用户写任务计划,linux——计划任务

    00 02 ls #每天的凌晨2点整执行 00 02 1 ls #每月的1日的凌晨2点整执行 00 02 14 2 ls #每年的2月14日凌晨2点执行 00 02 7 ls #每周天的凌晨2点整执行 ...

  7. linux 进程0 写时复制,linux 写时复制 COW 过程梳理

    最后一次谈到缺页,是在一年多以前,http://blog..net/chenyu105/article/details/7061845 那时结个了草率的尾,定格在了handle_pte_fault,留 ...

  8. linux 利用cat写文件名,在LINUX中如何用cat创建一个文件

    满意答案 怪盗丶末三 2013.09.06 采纳率:43%    等级:12 已帮助:12722人 cat 的创建.连接文件功能实例,如下 cat 有创建文件的功能,创建文件后,要以EOF或STOP结 ...

  9. linux pv信息写在哪里,linux命令PV介绍

    本次演示环境采用rpm安裝方式 rpm包下载安装 简单使用介绍: 复制文件限制到每秒1M到另外的目录下 pv -L 1m 11.sql > /tmp/12.sql 复制文件夹到另外一个文件夹下面 ...

  10. java如何让线程休眠一分钟_如何使线程在java中休眠特定的时间?

    当你的线程被中断击中时,它将进入InterruptedException catch块.然后,您可以检查线程花费了多少时间睡觉,并计算出睡眠时间.最后,不要吞咽异常,恢复中断状态是很好的做法,以便调用 ...

最新文章

  1. canvas烟花锦集
  2. 如何定义一个有效的OWIN Startup Class
  3. 使用Opencv进行轮廓检测,字符提取,简单的直方图字符识别!
  4. 什么样的程序员会让人讨厌
  5. invalid LOC header(bad signature)错误及解决
  6. jQuery - 按回车键触发跳转
  7. webgl天空盒边界缝隙_WebGL three.js进修笔记 法向量网格材质MeshNormalMaterial的引见和建立360度全景天空盒的要领...
  8. 分页实体类:PageBean
  9. 魅族开售跳票,创饥饿营销新高度?
  10. 怎么可以修改pr基本图形中的文字_视频剪辑 | pr的简单教学
  11. s5p6818/fs4418系统移植之uboot的移植
  12. 为什么要有域名,看完你就懂了。
  13. 迅雷 极速版 1.0.35.366
  14. git 团队协作正确操作流程
  15. 3个超神器工具,让你的电脑比手机好玩,值得收藏
  16. mock_httpserver
  17. 会声会影2022永久免费版新手小白必备视频剪辑工具
  18. x86下windbg查看SSDT表与SHDOWSSDT
  19. 我愿意去纳格兰的天空中翱翔 ----写给自己的亡灵盗贼(一)
  20. 基于Excel2013的数据导入

热门文章

  1. web网站搭建(nginx优化)二
  2. 先试试这一招,再决定是否要撬开拉杆箱的密码锁——巧开密码锁
  3. c语言如何关闭窗口,如何用C脚本关闭当前窗口?
  4. (CVPR 2017)VoxelNet: End-to-End Learning for Point Cloud Based 3D Object Detection
  5. 卡通头像生成器Avataaars generator
  6. CentOS 7 校对时间 修改时区
  7. 一条互联网广告多少钱?
  8. MyBase 与 HTML Help Workshop 编辑chm
  9. 【ESP32】 esp32 输入输出文件系统、编码
  10. mac系统如何管理桌面图标