七、读写锁

01. 读写锁概述
当有一个线程已经持有互斥锁时,互斥锁将所有试图进入临界区的线程都阻塞住。但是考虑一种情形,当前持有互斥锁的线程只是要读访问共享资源,而同时有其它几个线程也想读取这个共享资源,但是由于互斥锁的排它性,所有其它线程都无法获取锁,也就无法读访问共享资源了,但是实际上多个线程同时读访问共享资源并不会导致问题。

在对数据的读写操作中,更多的是读操作,写操作较少,例如对数据库数据的读写应用。为了满足当前能够允许多个读出,但只允许一个写入的需求,线程提供了读写锁来实现。

读写锁的特点如下:

1)如果有其它线程读数据,则允许其它线程执行读操作,但不允许写操作。

2)如果有其它线程写数据,则其它线程都不允许读、写操作。

读写锁分为读锁和写锁,规则如下:

1)如果某线程申请了读锁,其它线程可以再申请读锁,但不能申请写锁。

2)如果某线程申请了写锁,其它线程不能申请读锁,也不能申请写锁。

POSIX 定义的读写锁的数据类型是: pthread_rwlock_t。

02. 读写锁函数
2.1 读写锁初始化

七、读写锁_第1张图片

2.2 读写锁销毁

七、读写锁_第2张图片

2.3 申请读锁

七、读写锁_第3张图片

2.4 申请写锁

七、读写锁_第4张图片

2.5 释放读写锁

七、读写锁_第5张图片

03. 读写锁应用示例 

下面是一个使用读写锁来实现 4 个线程读写一段数据是实例。在此示例程序中,共创建了 4 个线程,其中两个线程用来写入数据,两个线程用来读取数据。当某个线程读操作时,其他线程允许读操作,却不允许写操作;当某个线程写操作时,其它线程都不允许读或写操作。

七、读写锁_第6张图片

七、读写锁_第7张图片

七、读写锁_第8张图片
测试结果:

七、读写锁_第9张图片

你可能感兴趣的:(linux系统编程)