找回密码
 注册
关于网站域名变更的通知
查看: 255|回复: 1
打印 上一主题 下一主题

Linux线程同步之读写锁

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-4-7 10:03 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
4 D! s; t6 z( o$ d5 h
1. 特性:6 i' K4 i0 h* b& v! P  M2 o
" f9 z  \2 |9 l. Y
    一次只有一个线程可以占有写模式的读写锁, 但是可以有多个线程同时占有读模式的读写锁. 正是因为这个特性,) v. a( M9 d2 o
7 ?# g* y1 g4 q8 P  s! k
当读写锁是写加锁状态时, 在这个锁被解锁之前, 所有试图对这个锁加锁的线程都会被阻塞.
1 ^7 Y# o) L# X8 J! j当读写锁在读加锁状态时, 所有试图以读模式对它进行加锁的线程都可以得到访问权, 但是如果线程希望以写模式对此锁进行加锁, 它必须阻塞知道所有的线程释放锁.
' x* I9 ]& U: U$ m) @* s6 k通常, 当读写锁处于读模式锁住状态时, 如果有另外线程试图以写模式加锁, 读写锁通常会阻塞随后的读模式锁请求, 这样可以避免读模式锁长期占用, 而等待的写模式锁请求长期阻塞.
! U8 u; ~5 P+ j+ O, S+ U2. 适用性:
# |- M# z4 O% z2 A$ F4 w, X
4 x& ^9 I$ {' R0 u    读写锁适合于对数据结构的读次数比写次数多得多的情况. 因为, 读模式锁定时可以共享, 以写模式锁住时意味着独占, 所以读写锁又叫共享-独占锁.
* w* o  l6 I4 I# x+ f, E6 v0 g6 I
3. 初始化和销毁:+ O1 _) {  D3 e# F, T+ w0 ~9 Q
. w$ p' t& ~0 h
#include <pthread.h>
# p2 T% y  }3 \& \8 c# }- H3 E# u8 Y  d% [1 n+ U2 L  A3 f
int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock, const pthread_rwlockattr_t *restrict attr);1 u' j7 R; M/ K/ Q# d* N( y
int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);9 a' s$ A# |$ f; G

0 J1 ~4 `3 s7 k, L7 C! D) S0 l成功则返回0, 出错则返回错误编号.
) R' |' t9 n9 P/ g% A$ R3 {% _
; S7 w, S& I% x: Y- }* Y' C: U1 f4 P同互斥量以上, 在释放读写锁占用的内存之前, 需要先通过pthread_rwlock_destroy对读写锁进行清理工作, 释放由init分配的资源.
, g" Y9 o5 O, W8 W3 h
3 C3 @: `, z# p) m, j, ?: P4. 读和写:" _1 R' ^% H% |' C7 D
5 M. K1 [1 F! L- H, k
#include <pthread.h>+ x9 k4 p8 [3 U2 ^. R
; R. r3 Q' r- Z/ o
int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock);0 o5 Y3 G8 o6 X4 r5 Z( }& X+ h/ B
int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock);: r( ~! Q0 G! @1 b
int pthread_rwlock_unlock(pthread_rwlock_t *rwlock);3 J) V' t% g0 J
( g, g1 ~1 u) y5 m% E4 n6 r, {& i6 ]
& d: H2 O6 J$ g( g
成功则返回0, 出错则返回错误编号.
' {4 T" v( q  x4 S& N* |* q4 _# F6 O% K. o% T8 @
  这3个函数分别实现获取读锁, 获取写锁和释放锁的操作. 获取锁的两个函数是阻塞操作, 同样, 非阻塞的函数为:
% r8 F0 |" k' B$ }6 h
, H8 R/ B3 |  C, \& G#include <pthread.h>
" h+ I/ r; G' z; }8 b
" s+ g2 [7 c. |* i3 b5 nint pthread_rwlock_tryrdlock(pthread_rwlock_t *rwlock);
7 c3 G2 [  x# ?$ Q/ T3 sint pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock);
1 g1 V. N& @9 I
  ?/ k0 \; ?3 n' S7 m9 F2 }成功则返回0, 出错则返回错误编号.
% [. Y7 F, J" S. B& v1 q& L) F% i0 Q& |2 R' v
非阻塞的获取锁操作, 如果可以获取则返回0, 否则返回错误的EBUSY.. F; n4 e9 t5 V1 |, _4 A' S

, v$ j  v% s5 j$ M9 x9 n' _# {* ~2 v- `5. 属性设置1 B1 ]3 W$ ?5 l5 `# I5 i

7 T& ]4 ?2 g1 S9 C: o#include <pthread.h>6 E5 ?. T/ t& i0 \
int pthread_rwlockattr_init(pthread_rwlockattr_t *attr);
1 b% B  g4 Z& y9 R6 dint pthread_rwlockattr_destroy(pthread_rwlockattr_t *attr);
; M; U8 i( g9 ~& }8 h+ R4 _     int pthread_rwlockattr_getpshared(const pthread_rwlockattr_t *restrict attr, int *restrict pshared);0 \! n, H# b- T
    int pthread_rwlockattr_setpshared(pthread_rwlockattr_t *attr,int pshared);
  Y$ E4 ^7 U. A4 ?' e; D8 D+ e. n0 C% R0 i
   pthread_rwlockattr_setkind_np (attr, pref)

该用户从未签到

2#
发表于 2020-4-7 18:32 | 只看该作者
Linux线程同步之读写锁
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-10-26 02:15 , Processed in 0.125000 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表