读写锁与自旋锁

一、读写锁

1、特点

读写锁比mutex有更高的适用性,可以多个线程同时占用读模式的读写锁,但是只能一个线程占用写模式的读写锁。
(1)当读写锁是写加锁状态时,在这个锁被解锁之前,所有试图对这个锁加锁的线程都会被阻塞;
(2)当读写锁在读加锁状态时,所有试图以读模式对它进行加锁的线程都可以得到访问权,但是以写模式对它进行枷锁的线程将阻塞;
(3)当读写锁在读模式锁状态时,如果有另外线程试图以写模式加锁,读写锁通常会阻塞随后的读模式锁请求,这样可以避免读模式锁长期占用,而等待的写模式锁请求长期阻塞;

2、适用性

读写锁适合于对数据结构的读次数比写次数多得多的情况。 因为, 读模式锁定时可以共享, 以写模式锁住时意味着独占, 所以读写锁又叫共享-独占锁。

3、相关函数

#include < pthread.h >

初始化和销毁

 int pthread_rwlockattr_init(pthread_rwlockattr_t *attr);
 int pthread_rwlockattr_destroy(pthread_rwlockattr_t *attr);

返回值:成功返回0,失败返回错误编号。

属性设置

int pthread_rwlockattr_getpshared (const pthread_rwlockattr_t * restrict  attr, int *restrict  pshared);  

设置读写锁属性对象,标识在进程间共享与否

int pthread_rwlockattr_setpshared (pthread_rwlockattr_t *attr, int pshared); 

可用来设置由进程共享的读写锁属性。

返回值:成功返回0,失败返回错误编号。

读和写

int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock); 
int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock); 
int pthread_rwlock_unlock(pthread_rwlock_t *rwlock); 

返回值:成功则返回0, 出错则返回错误编号。
这3个函数分别实现获取读锁, 获取写锁和释放锁的操作, 获取锁的两个函数是阻塞操作。

  • 销毁与释放读写锁区别
    解除读写锁只解除读写锁对象中持有的锁,将对象中持有的锁全部解除后,读写锁对象将处于无属主、解除锁定状态,但读写锁对象仍然存在。而销毁读写锁是直接销毁锁,读写锁对象消失。

二、自旋锁

自旋锁与互斥锁比较类似,它们都是为了解决对某项资源的互斥使用。无论是互斥锁,还是自旋锁,在任何时刻最多只能有一个执行单元获得锁。但是两者在调度机制上略有不同。对于互斥锁,如果资源已经被占用,资源申请者只能进入睡眠状态。但是自旋锁不会引起调用者睡眠,如果自旋锁已经被别的执行单元保持,调用者就一直循环在那里看是否该自旋锁的保持者已经释放了锁。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值