線程解析(三)
時間:2016-12-30作者:華清遠見
前面我們說了線程的創(chuàng)建和撤銷,這里我們說一下線程間的同步的問題。 當(dāng)同一個進程中存在多個線程的時候,多個線程共享相同的內(nèi)存,確保每個線程能夠看到一致的數(shù)據(jù)視圖,如果每個線程中都不會讀取或修改共同享有的變量,就不會存在一致性的問題,同樣如果共享變量時只讀的也就不會存在這個問題。但是,當(dāng)某個線程可一個修改變量,而其他的線程去讀取或修改這個變量的時候,就需要進行線程間的同步,確保他們訪問變量的內(nèi)容時不會訪問到無效的數(shù)據(jù)。 這里介紹一種實現(xiàn)同步的方法:互斥量 互斥鎖本質(zhì)上是一把鎖,在訪問共享資源的時候?qū)コ饬窟M行加鎖,訪問結(jié)束后解鎖。在這里我們說一下如何去操作互斥鎖。 1、 創(chuàng)建和撤銷
互斥量用pthread_mutex_t數(shù)據(jù)類型來表示,在使用之前必須對其進行初始化,用完之后釋放內(nèi)存。互斥量初始化可以用PTHREAD_MUTEX_INITIALIZER來初始化(靜態(tài)初始化),亦可以使用pthread_mutex_init函數(shù)來實現(xiàn),這種方法動態(tài)的為互斥量分配內(nèi)存,使用后必須使用pthread_mutex_destroy來釋放內(nèi)存單元。下面是這些函數(shù)的原型: 2、 鎖操作
鎖操作主要包括加鎖pthread_mutex_lock()、解鎖pthread_mutex_unlock()和測試鎖pthread_mutex_trylock()三個。通過pthread_mutex_lock對互斥量加鎖,這里需要獲得鎖,如果無法獲得鎖則調(diào)用線程將阻塞到其他線程調(diào)用pthread_mutex_unlock對互斥量解鎖。 如果線程不希望被阻塞,則可以調(diào)用pthread_mutex_trylock嘗試對互斥量進行加鎖,當(dāng)互斥量沒有被加鎖,則函數(shù)返回0,并鎖住互斥量,否則會失敗,返回EBUSY. 3、 示例 下面我們用一個例程說明一下這些函數(shù)的使用。
#include <stdio.h> pthread_mutex_t mutex;
void *thread_a(void *arg)
void *thread_b(void *arg)
int main(int argc, char **argv)
if(pthread_mutex_init(&mutex, NULL) != 0)
err = pthread_create(&tid_a,NULL,thread_a,NULL);
sleep(20);
結(jié)果: 由這里的結(jié)果可以看出mutex的用處及幾個相關(guān)函數(shù)的使用方法。 相關(guān)資訊
發(fā)表評論
|