|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
为保证每个线程对同一资源访问有效,比如一个线程想要从共享资源读数据,而这些资源正在被其他线程修改,那么读出来的数据是无效的,那么就要想办法让其他线程修改完再去读,这时候就用到了同步机制。可以使用Linux系统提供的机制来对线程访问资源的顺序进行同步,本文档挑选了信号量,互斥锁,条件变量来介绍线程同步机制,实验代码在sync/目录下。2 j- H3 h9 X3 m2 o) A2 _
; \& U9 ~' i0 P4 J& ? I2 r1 POSIX无名信号量
; R% u) W+ q: y; I0 p本章介绍POSIX 无名信号量,以下简称信号量。信号量类似于计数器,操作方法和前面的System V 信号灯基本一样。* W: v2 _0 l* Y- P, s [ r
使用信号量的步骤: c3 I9 P* Y* o3 K+ k
1.在程序全局区定义信号量;
* m% v/ O9 P% v, b2.使用seminit()初始化信号量;" k \0 d( u9 B% v
3.使用sem_wait()和sem_post()对信号量进行P/V操作;
+ m, l) X! y- m. Z5 u/ Y4.使用sem_destroy()销毁信号量。
* r- i7 T* z6 ^5 K# j- J4 |' o
3 B$ v. b3 A3 E9 Q( b1 p/ w( {; q信号量常用函数如下:# b+ {+ Q! Y3 [9 L
sem_init():对信号量值进行初始化,
2 H7 L9 i5 S3 ?8 h# C#include# ^( G t5 H2 w: w& Q3 Z% R- Z% k* @6 n
int sem_init(sem_t *sem, int pshared, unsigned int value);
1 M; ^5 ]+ Q; j3 D参数含义:
2 N" p0 J! v3 {1 ?- L) e! Fsem:指针,指向定义的信号量;
; y5 c z# t; P$ Cpshared:指明这个信号量用于进程还是线程,0为线程,不等于0为进程,本节填写为0。- s) {6 K8 S8 G" F% K' l2 b
value:信号量初始值
a+ s5 r# `/ u D* \返回值:成功返回0,错误返回-1。
9 v0 C1 `" k8 e6 z
2 g; ~' ^! f" A% usem_wait():等待一个信号量,进行P操作,信号量值-1;' T/ \5 V) w0 _; }9 ]% ~
sem_post():唤醒一个信号量,进行V操作,信号量值+1,定义如下:
; y, v5 q& H, B. A#include5 N8 g ~ `; {
int sem_wait(sem_t *sem);1 P5 ?, w3 H- d/ k
int sem_post(sem_t *sem);7 f- [4 M. D" }
参数含义:
! r# L7 s" J$ H8 K* z) osem:要操作的信号量;
/ s7 T; d$ }8 b8 g返回值:成功返回0,错误返回-1。
2 L; \0 E2 d/ G) G8 o x% r2 e4 F: X0 s/ k/ o5 q
sem_destroy():销毁初始化后的信号量
/ B+ I& @1 _7 E ]. j- f& V( f; {#include& t$ w' L% |) j" u9 a
int sem_destroy(sem_t *sem); F2 B" }7 ^. D1 X0 L4 k3 P! W
sem:要操作的信号量;/ N, X! [5 R) X" q
返回值:成功返回0,错误返回-1。
: ?) r- Y% q! V, l( `: X) m' |# J1 o8 x5 r- E
实验代码在sync/sem.c:路径为:11_Linux系统开发进阶\Linux系统编程_章节使用资料。
# i9 O5 w7 e! l( X) c& v使用信号量控制读写线程,初始化时写信号量为1,读信号量为0,那么读线程就会阻塞,写线程就会执行并将写信号-1,写线程在fgets等待输入,当输入完成后,将读信号+1唤醒读线程,这样读写线程交替执行就完成了同步。0 f% s( z \ V$ d+ k8 y5 y
% z' r2 V4 ] i( ?: V, G$ z5 i$ ] G
![]()
0 ]' y8 d6 p! r$ Y+ i
$ ~7 e+ `) C g7 z! i5 P) P![]()
8 r& n; E# j1 G2 k0 Y$ C: A3 K, ^ W2 j- J$ T) q+ f1 l
|
|