久久ER99热精品一区二区-久久精品99国产精品日本-久久精品免费一区二区三区-久久综合九色综合欧美狠狠

新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > 多線程編程之:Linux線程編程

多線程編程之:Linux線程編程

作者: 時間:2013-09-13 來源:網絡 收藏


本文引用地址:http://cqxgywz.com/article/257101.htm

2.信號量線程控制

(1)信號量說明。

在第8章中已經講到,信號量也就是中所用到的PV原子操作,它廣泛用于進程或線程間的同步與互斥。信號量本質上是一個非負的整數計數器,它被用來控制對公共資源的訪問。這里先來簡單復習一下PV原子操作的工作原理。


PV原子操作是對整數計數器信號量sem的操作。一次P操作使sem減一,而一次V操作使sem加一。進程(或線程)根據信號量的值來判斷是否對公共資源具有訪問權限。當信號量sem的值大于等于零時,該進程(或線程)具有公共資源的訪問權限;相反,當信號量sem的值小于零時,該進程(或線程)就將阻塞直到信號量sem的值大于等于0為止。


PV原子操作主要用于進程或線程間的同步和互斥這兩種典型情況。若用于互斥,幾個進程(或線程)往往只設置一個信號量sem,它們的操作流程如圖9.2所示。


當信號量用于同步操作時,往往會設置多個信號量,并安排不同的初始值來實現它們之間的順序執行,它們的操作流程如圖9.3所示。


圖9.2 信號量互斥操作 圖9.3 信號量同步操作


(2)函數說明。

實現了POSIX的無名信號量,主要用于線程間的互斥與同步。這里主要介紹幾個常見函數。


n sem_init()用于創建一個信號量,并初始化它的值。

n sem_wait()和sem_trywait()都相當于P操作,在信號量大于零時它們都能將信號量的值減一,兩者的區別在于若信號量小于零時,sem_wait()將會阻塞進程,而sem_trywait()則會立即返回。

n sem_post()相當于V操作,它將信號量的值加一同時發出信號來喚醒等待的進程。

n sem_getvalue()用于得到信號量的值。

n sem_destroy()用于刪除信號量。


(3)函數格式。

表9.7列出了sem_init()函數的語法要點。

表9.7 sem_init()函數語法要點

所需頭文件

#include semaphore.h>

函數原型

int sem_init(sem_t *sem,int pshared,unsigned int value)

函數傳入值

sem:信號量指針

pshared:決定信號量能否在幾個進程間共享。由于目前還沒有實現進程間共享信號量,所以這個值只能夠取0,就表示這個信號量是當前進程的局部信號量

value:信號量初始化值

函數返回值

成功:0

出錯:-1


表9.8列出了sem_wait()等函數的語法要點。

表9.8 sem_wait()等函數語法要點

所需頭文件

#include pthread.h>

函數原型

int sem_wait(sem_t *sem)
int sem_trywait(sem_t *sem)
int sem_post(sem_t *sem)
int sem_getvalue(sem_t *sem)
int sem_destroy(sem_t *sem)

函數傳入值

sem:信號量指針

函數返回值

成功:0

出錯:-1

linux操作系統文章專題:linux操作系統詳解(linux不再難懂)

linux相關文章:linux教程




評論


相關推薦

技術專區

關閉