课时83+84_读写锁的特性+使用场景
文章目录
1、读写锁的特性
1、读写锁是几把锁
读写锁只有一把锁,有读属性和写属性。
pthread_rwlock_t lock;
2、读写锁的类型
(1)读锁:对内存做读操作
(2)写锁:对内存做写操作
3、读写锁的特性
(1)线程A加读锁成功,又来了三个线程,做读操作,可以加锁成功。读共享---并行处理
(2)线程A加写锁成功,又来了三个线程,做读操作,三个线程阻塞。写独占---串行处理
(3)线程A加读锁成功,又来了B线程加写锁阻塞,又来了C线程加读锁阻塞。读写不能同时
写的优先级高
线程A解锁后,线程B处理,线程B解锁后,线程C处理。
2、读写锁的使用场景
2.1、线程A加写锁成功,线程B请求读锁
线程B阻塞
:读写不能同时
2.2、线程A持有读锁,线程B请求写锁
线程B阻塞
:读写不能同时
2.3、线程A持有读锁,线程B请求读锁
线程B加锁成功
:读共享,并行处理
2.4、线程A持有读锁,然后线程B请求写锁,然后线程C请求读锁
线程B阻塞
:读写不能同时线程C阻塞
:写优先级高
访问顺序:
A线程解锁,B线程加写锁成功,C线程继续阻塞;B线程解锁,C线程加读锁成功。
2.5、线程A持有写锁,然后线程B请求读锁,然后线程C请求写锁
线程B、线程C 阻塞
:读写不能同时,写优先级高
访问顺序:
A线程解锁,C线程加写锁成功,B线程继续阻塞;-----写优先级高
C线程解锁,B线程加读锁成功。
3、互斥锁、读写锁的选择
互斥锁:读写串行
读写锁:读并行,写串行
如果程序的读操作频繁度>写操作频繁度,适用读写锁效率更高
如果程序中都是写操作,互斥锁和读写锁作用相同。
来源:https://blog.csdn.net/sznari2012/article/details/100859958