本文主要是介绍Linux系统编程_课时83+84_读写锁的特性+使用场景,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
课时83+84_读写锁的特性+使用场景
文章目录
- 课时83+84_读写锁的特性+使用场景
- 1、读写锁的特性
- 1、读写锁是几把锁
- 2、读写锁的类型
- 3、读写锁的特性
- 2、读写锁的使用场景
- 2.1、线程A加写锁成功,线程B请求读锁
- 2.2、线程A持有读锁,线程B请求写锁
- 2.3、线程A持有读锁,线程B请求读锁
- 2.4、线程A持有读锁,然后线程B请求写锁,然后线程C请求读锁
- 2.5、线程A持有写锁,然后线程B请求读锁,然后线程C请求写锁
- 3、互斥锁、读写锁的选择
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、互斥锁、读写锁的选择
互斥锁:读写串行
读写锁:读并行,写串行
如果程序的读操作频繁度>写操作频繁度,适用读写锁效率更高
如果程序中都是写操作,互斥锁和读写锁作用相同。
这篇关于Linux系统编程_课时83+84_读写锁的特性+使用场景的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!