博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
pthread_rwlock pthread读写锁
阅读量:6470 次
发布时间:2019-06-23

本文共 2920 字,大约阅读时间需要 9 分钟。

原文: 

使用读写锁

配置读写锁的属性之后,即可初始化读写锁。以下函数用于初始化或销毁读写锁、锁定或解除锁定读写锁或尝试锁定读写锁。下表列出了本节中讨论的用来处理读写锁的函数。

表 4–9 处理读写锁的例程

 

操作

相关函数说明

初始化读写锁

读取读写锁中的锁

读取非阻塞读写锁中的锁

写入读写锁中的锁

写入非阻塞读写锁中的锁

解除锁定读写锁

销毁读写锁

---------------------------------------------------------------------------------------

1、概述

  读写锁与互斥量类似,不过读写锁允许更高的并行性。互斥量要么是锁住状态,要么是不加锁状态,而且一次只有一个线程对其加锁。读写锁可以有三种状态:读模式下加锁状态,写模式下加锁状态,不加锁状态。一次只有一个线程可以占有写模式的读写锁,但是多个线程可用同时占有读模式的读写锁。读写锁也叫做共享-独占锁,当读写锁以读模式锁住时,它是以共享模式锁住的,当它以写模式锁住时,它是以独占模式锁住的。

2、读写锁API

  读写锁的数据类型为pthread_rwlock_t。如果这个类型的某个变量是静态分配的,那么可通过给它赋常值PTHREAD_RWLOCK_INITIALIZER来初始化它。

获取和释放读写锁:

int pthread_rwlock_rdlock(pthread_rwlock_t *rwptr); //获取一个读出锁
int pthread_rwlock_wrlock(pthread_rwlock_t *rwptr); //获取一个写入锁
int pthread_rwlock_unlock(pthread_rwlock_t *rwptr); //释放一个写入锁或者读出锁
都返回:成功时为0,出错时为正的Exxx值
int pthread_rwlock_tryrdlock(pthread_rwlock_t *rwptr);
int pthread_rwlock_trywrlock(pthread_rwlock_t *rwptr);
都返回:成功时为0,出错时为正的Exxx值

读写锁属性:

int pthread_rwlock_init(pthread_rwlock_t *rwptr, const pthread_rwlockattr_t *attr)
int pthread_rwlock_destroy(pthread_rwlock_t *rwptr);
都返回:成功时为0,出错时为正的Exxx值

int pthread_rwlockattr_init(pthread_rwlockattr_t *attr);

int pthread_rwlockattr_destroy(pthread_rwlockattr_t *attr);
都返回:成功时为0,出错时为正的Exxx值

int pthread_rwlockattr_getpshared(const pthread_rwlockattr_t *attr, int *valptr);

int pthread_rwlockattr_setpshared(pthread_rwlockattr_t *attr, int valptr);
都返回:成功时为0,出错时为正的Exxx值

 

#include 
#include
#include
#include
#include
#include
#define MAXDATA 1024#define MAXREDER 100#define MAXWRITER 100struct{ pthread_rwlock_t rwlock; char datas[MAXDATA]; } shared = { PTHREAD_RWLOCK_INITIALIZER};void *reader(void *arg);void *writer(void *arg);int main(int argc,char *argv[]){ int i,readercount,writercount; pthread_t tid_reader[MAXREDER],tid_writer[MAXWRITER]; if(argc != 3) { printf("usage :
#
#
\n"); exit(0); } readercount = atoi(argv[1]); writercount = atoi(argv[2]); pthread_setconcurrency(readercount+writercount); for(i=0;i

  

打印输出

 

[root@localhost pthread_rwlock]# ./run 5 1Writers begings write message.Enter the write message: sdfsReader begins read message.Reader begins read message.Reader begins read message.Reader begins read message.Reader begins read message.Read message is: sdfsRead message is: sdfsRead message is: sdfsRead message is: sdfsRead message is: sdfs[root@localhost pthread_rwlock]#

我在read中加入sleep,看家其他read线程也进入了,表明一次只有一个线程可以占有写模式的读写锁,但是多个线程可用同时占有读模式的读写锁。

 另外请关注pthread_setconcurrency();

 最近在code review一些人的代码的时候,发现了一个问题,就是很少人关注pthread_setconcurrency()函数,其实这个函数在pthread中是一个很重要的函数。在linux下,如果你忽略了这个函数的使用,那么能够并发的线程数目由实现者来控制,对于系统调度的效率而言往往不是什么好的事情,因为默认的设置往往不是最佳的。

     更为糟糕的是,如果在某些系统中,如果你不调用pthread_setconcurrency()函数,那么系统中的运行的线程仅仅是第一个被创建的线程,其他线程根本不会被运行。比如在solaris 2。6中就有这些情况。为了在unix或者是linux系统上使移植更加的容易,请不要忘记在适当的地方调用次函数,清晰的告诉系统我们使用的线程个数。虽然在某些系统上,这个调用是徒劳的,但是它的使用增强的移植性!

你可能感兴趣的文章
项目中的积累,及常见小问题
查看>>
Python类型转换、数值操作(收藏)
查看>>
Resin配置
查看>>
objective-C 类别/协议。
查看>>
sersync+rsync实时备份
查看>>
城市交通治安卡口系统解决方案
查看>>
阿里巴巴的导购效果跟踪
查看>>
万方安全:信息系统的风险评估过程与评估方法
查看>>
flex布局下的flex-grow、flex-shrink、flex-basis属性详解
查看>>
是什么样的骚操作让应用上线节省90%的时间
查看>>
netty Reactor模式(源码死磕3)
查看>>
NIO总结
查看>>
CAD图纸上标注的箭头端上面的样式怎么改变?
查看>>
ESXI 安装过程
查看>>
postfix+mysql+dovecot+extmail 邮件系统
查看>>
《其实你不懂wget的心》
查看>>
9.5 at crontab命令学习
查看>>
python获取本地IP地址发送邮件
查看>>
nginx+php-fpm出现502 bad gateway错误解决方法
查看>>
一个python程序
查看>>