|
|
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) |
|