pthread讀寫鎖(轉(zhuǎn))Linux 2010-03-21 23:26:02 閱讀272 評論0 字號:大中小 訂閱 讀寫鎖 索引:
1.初始化一個讀寫鎖pthread_rwlock_init #include <pthread.h>int pthread_rwlock_init(pthread_rwlock_t *rwlock, \ const pthread_rwlockattr_t *attr);返回值:函數(shù)成功返回0;任何其他返回值都表示錯誤 初始化rwlock指定的讀寫鎖,它的屬性被參數(shù)attr指定。如果attr的值為NULL,初始化讀寫鎖時使用缺省的讀寫鎖屬性。其效果和attr指向一個缺省的讀寫鎖屬性對象是一樣的。 成功初始化后,讀寫鎖的狀態(tài)為非鎖定的。 對一個已經(jīng)初始化過的讀寫鎖調(diào)用pthread_rwlock_init函數(shù)會產(chǎn)生不可預(yù)測的后果。使用一個未經(jīng)初始化的讀寫鎖也會產(chǎn)生不可預(yù)測的后果。 如果需要缺省屬性的讀寫鎖,可以用宏P(guān)THREAD_RWLOCK_INITIALIZER初始化靜態(tài)的讀寫鎖變量。但是,靜態(tài)初始化讀寫鎖不進(jìn)行錯誤檢查。如: pthread_rwlock_t rwlock = PTHREASD_RWLOCK_INITIALIZER;
2.讀鎖定讀寫鎖pthread_rwlock_rdlock #include <pthread.h>int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock);返回值:函數(shù)成功返回0;任何其他返回值都表示錯誤 函數(shù)在rwlock讀寫鎖上進(jìn)行讀鎖定。 如果一個線程寫鎖定了讀寫鎖,調(diào)用pthread_rwlock_rdlock函數(shù)的線程將無法讀鎖定讀寫鎖,并將被阻塞,直到線程可以讀鎖定這個讀寫鎖為止。 如果一個線程寫鎖定了讀寫鎖后又調(diào)用pthread_rwlock_rdlock函數(shù)來讀鎖定同一個讀寫鎖,結(jié)果將無法預(yù)測。 標(biāo)準(zhǔn)中沒有指定當(dāng)沒有線程寫鎖定這個讀寫鎖,但有線程試圖寫鎖定而被阻塞在這個讀寫鎖上時,當(dāng)前線程是否能讀鎖定讀寫鎖。大多數(shù)線程庫往往優(yōu)先考慮激活試圖寫鎖定而被阻塞的線程,這樣做是為了防止試圖寫鎖定而被阻塞的線程長時間得不到調(diào)度。 一個線程可能對一個讀寫鎖進(jìn)行了多次讀鎖定(即成功調(diào)用了pthread_rwlock_rdlock()函數(shù)多次)。如果是這樣的,線程必須調(diào)用pthread_rwlock_unlock()函數(shù)對讀寫鎖進(jìn)行同樣次數(shù)的解鎖。 當(dāng)一個讀寫鎖被讀鎖定了,而一個線程阻塞在這個讀寫鎖上時,如果這時來了一個信號,那么當(dāng)線程從信號處理程序中返回時,將繼續(xù)阻塞在這個讀寫鎖上。就好象線程沒有被中斷過。
3.非阻塞讀鎖定pthread_rwlock_tryrdlock #include <pthread.h>int pthread_rwlock_tryrdlock(pthread_rwlock_t *rwlock);返回值:函數(shù)成功返回0;任何其他返回值都表示錯誤 pthread_rwlock_tryrdlock()函數(shù)和pthread_rwlock_rdlock函數(shù)的功能相近,不同的是,當(dāng)已有線程寫鎖定讀寫鎖,或是有試圖寫鎖定的線程被阻塞時,pthread_rwlock_tryrdlock函數(shù)失敗返回。
4.寫鎖定讀寫鎖pthread_rwlock_wrlock #include <pthread.h>int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock);返回值:函數(shù)成功返回0;任何其他返回值都表示錯誤 寫鎖定讀寫鎖rwlock。如果沒有線程讀或?qū)戞i定讀寫鎖rwlock,當(dāng)前線程將寫鎖定讀寫鎖rwlock。否則線程將被阻塞,直到?jīng)]有線程鎖定這個讀寫鎖為止。 如果調(diào)用這個函數(shù)之前,本線程已經(jīng)讀或?qū)戞i定了這個讀寫鎖,那么pthread_rwlock_wrlock函數(shù)運(yùn)行的結(jié)果是不可預(yù)測的。 讀寫鎖被解開以后,激活阻塞在讀寫鎖上的線程時,往往優(yōu)先考慮試圖寫鎖定而被阻塞的線程,這樣做是為了防止試圖寫鎖定而被阻塞的線程長時間得不到調(diào)度。 當(dāng)一個讀寫鎖被寫鎖定了,而一個線程阻塞在這個讀寫鎖上時,如果這時來了一個信號,那么當(dāng)線程從信號處理程序中返回時,將繼續(xù)阻塞在這個讀寫鎖上。就好像線程沒有被中斷過。
5.非阻塞寫鎖定pthread_rwlock_trywrlock #include <pthread.h>int pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock);返回值:函數(shù)成功返回0;任何其他返回值都表示錯誤 pthread_rwlock_trywrlock函數(shù)的功能和pthread_rwlock_wrlock函數(shù)相近。不同的是如果有其他線程鎖定了讀寫鎖,pthread_rwlock_trywrlock函數(shù)會失敗返回。
6.解鎖讀寫鎖pthread_rwlock_unlock #include <pthread.h>int pthread_rwlock_unlock(pthread_rwlock_t *rwlock);返回值:函數(shù)成功返回0;任何其他返回值都表示錯誤 解鎖一個讀寫鎖。 調(diào)用pthread_rwlock_unlock函數(shù)之前必須調(diào)用pthread_rwlock_rdlock函數(shù)或pthread_rwlock_wrlock函數(shù)鎖定讀寫鎖。否則結(jié)果是不可預(yù)測的。 在pthread_rwlock_unlock函數(shù)被用來解鎖對讀寫鎖的讀鎖定后,如果本線程對這個讀寫鎖還有其他讀鎖定,那么這個讀寫鎖對本線程將繼續(xù)保持讀鎖定狀態(tài)。如果pthread_rwlock_unlock函數(shù)解開了當(dāng)前線程在這個讀寫鎖上的最后一個讀鎖定,那么當(dāng)前線程將不再擁有對這個讀寫鎖的讀鎖定。如果pthread_rwlock_unlock函數(shù)解開了這個讀寫鎖上的最后一個鎖定,那么這個讀寫鎖將處在非鎖定狀態(tài)。 如果pthread_rwlock_unlock函數(shù)被用來解鎖對讀寫鎖的寫鎖定,那么函數(shù)返回后,這個讀寫鎖將處在非鎖定狀態(tài)。 如果用pthread_rwlock_unlock函數(shù)解鎖一個讀寫鎖時,有多個線程在等待對這個讀寫鎖進(jìn)行寫鎖定,系統(tǒng)將用調(diào)度策略決定激活哪個線程對讀寫鎖進(jìn)行寫鎖定。 如果用pthread_rwlock_unlock函數(shù)解鎖一個讀寫鎖時,有多個線程在等待對這個讀寫鎖進(jìn)行讀鎖定,系統(tǒng)將用調(diào)度策略決定按什么順序激活各個線程對讀寫鎖進(jìn)行讀鎖定。 如果用pthread_rwlock_unlock函數(shù)解鎖一個讀寫鎖時,有多個線程在等待對這個讀寫鎖進(jìn)行寫鎖定和讀鎖定,一般先激活需要寫鎖定的線程對讀寫鎖進(jìn)行寫鎖定(標(biāo)準(zhǔn)沒有指定在這種情況下應(yīng)該先激活寫線程還是先激活讀線程)。
7.釋放讀寫鎖pthread_rwlock_destroy #include <pthread.h>int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);返回值:函數(shù)成功返回0;任何其他返回值都表示錯誤 釋放讀寫鎖rwlock,并釋放這個讀寫鎖占用的資源。一般情況下,pthread_rwlock_destroy函數(shù)將rwlock指向的互斥鎖對象設(shè)置為非法值。 釋放了一個讀寫鎖之后,在pthread_rwlock_init重新初始化它之前,再使用這個讀寫鎖會有不可預(yù)料的結(jié)果。 如果有線程鎖定了某個讀寫鎖,那么用pthread_rwlock_destroy()函數(shù)釋放這個讀寫鎖會引起不可預(yù)知的結(jié)果。 試圖釋放一個未初始化的讀寫鎖會引起不可預(yù)知的結(jié)果。 |
|