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

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

 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值

读写锁在不同进程间共享:

PTHREAD_PROCESS_SHARED

线程取消

通过由对方调用函数pthread_cancel,一个线程可以被同一个进程内的任何其他线程所取消(cancel):
int pthread_cancel(pthread_t tid);
都返回:成功时为0,出错时为正的Exxx值

为处理被取消的可能情况,任何线程可以安装(压入)和删除(弹出)清理处理程序:

void pthread_cleanup_push(void (*function)(void *), void *arg);
void pthread_cleanup_pop(int execute);
这些处理程序就是发生以下情况时被调用的函数:
1. 调用线程被取消(有某个线程调用pthread_cancel完成)
2. 调用线程自愿终止(或者通过调用pthread_exit,或者从自己的线程起始函数返回)

写个程序实现读者-写者问题,程序如下:

#include 
#include
#include
#include
#include
#include
#define MAXDATA 1024 #define MAXREDER 100 #define MAXWRITER 100 struct { 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

程序执行结果如下所示:

转载于:https://www.cnblogs.com/alantu2018/p/8466257.html

你可能感兴趣的文章
js如何将字符串作为函数名调用函数
查看>>
Android程序的安装和打包
查看>>
P1508 Likecloud-吃、吃、吃
查看>>
HTML.3列表
查看>>
第 19 章 用户帐号
查看>>
PSR-1 基础编码规范
查看>>
Hive UDF开发实例学习
查看>>
5B - 一只小蜜蜂...
查看>>
消息队列NetMQ 原理分析4-Socket、Session、Option和Pipe
查看>>
dns 查询中的ANY类型
查看>>
ORA-600 各个参数含义说明
查看>>
虚拟地址转换为物理地址【转】
查看>>
linux中的优先搜索树的实现--prio_tree【转】
查看>>
php抽象类和接口
查看>>
php 解压 .gz 文件
查看>>
EM算法
查看>>
Binary Tree Longest Consecutive Sequence
查看>>
实战:RIP和EIGRP路由再发布
查看>>
统计数据库大小
查看>>
python运维开发之socket网络编程02
查看>>