青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

<2006年9月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

統計

  • 隨筆 - 44
  • 文章 - 0
  • 評論 - 86
  • 引用 - 0

常用鏈接

留言簿(6)

隨筆分類(31)

隨筆檔案(44)

Mining

最新隨筆

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

Linux 下的線程讀寫鎖
有一種寫優先讀寫鎖,有如下特點:
1)多個讀者可以同時進行讀
2)寫者必須互斥(只允許一個寫者寫,也不能讀者寫者同時進行)
3)寫者優先于讀者(一旦有寫者,則后續讀者必須等待,喚醒時優先考慮寫者)

在Solaris 中直接提供了讀寫鎖, 但是在Linux 中只提供了線程的讀寫鎖, 這里記錄了一些讀寫鎖的資料.

1.Solaris .vs. Linux Posix 庫函數

Solaris 庫(lib 線程)Linux POSIX 庫(libp 線程)操作
sema_destroy()sem_destroy()銷毀信號狀態。
sema_init()sem_init()初始化信號。
sema_post()sem_post()增加信號。
sema_wait()sem_wait()阻止信號計數。
sema_trywait()sem_trywait()減少信號計數。
mutex_destroy()pthread_mutex_destroy()銷毀或禁用與互斥對象相關的狀態。
mutex_init()pthread_mutex_init()初始化互斥變量。
mutex_lock()pthread_mutex_lock()鎖定互斥對象和塊,直到互斥對象被釋放。
mutex_unlock()pthread_mutex_unlock()釋放互斥對象。
cond_broadcast()pthread_cond_broadcast()解除對等待條件變量的所有線程的阻塞。
cond_destroy()pthread_cond_destroy()銷毀與條件變量相關的任何狀態。
cond_init()pthread_cond_init()初始化條件變量。
cond_signal()pthread_cond_signal()解除等待條件變量的下一個線程的阻塞。
cond_wait()pthread_cond_wait()阻止條件變量,并在最后釋放它。
rwlock_init()pthread_rwlock_init()初始化讀/寫鎖。
rwlock_destroy()pthread_rwlock_destroy()鎖定讀/寫鎖。
rw_rdlock()pthread_rwlock_rdlock()讀取讀/寫鎖上的鎖。
rw_wrlock()pthread_rwlock_wrlock()寫讀/寫鎖上的鎖。
rw_unlock()pthread_rwlock_unlock()解除讀/寫鎖。
rw_tryrdlock()pthread_rwlock_tryrdlock()讀取非阻塞讀/寫鎖上的鎖。
rw_trywrlock()pthread_rwlock_trywrlock()寫非阻塞讀/寫鎖上的鎖。


2.使用mutex 來實現

設置三個互斥信號量:
rwmutex?? ??? ?用于寫者與其他讀者/寫者互斥的訪問共享數據
rmutex?? ??? ?用于讀者互斥的訪問讀者計數器readcount
nrmutex?? ??? ?用于寫者等待已進入讀者退出,所有讀者退出前互斥寫操作

var?? rwmutex,rmutex,nrmutex:semaphore:=1,1,1; ?
int?? readcount=0;

cobegin
?? ?reader begin
?? ??? ?P(rwmutex);
?? ??? ?P(rmutex);
?? ??? ?readcount++;
?? ??? ?if (readcount == 1) P(nrmutex);? //有讀者進入,互斥寫操作
?? ??? ?V(rmutex);
?? ??? ?V(rwmutex);? //及時釋放讀寫互斥信號量,允許其它讀、寫進程申請資源讀數據;
?? ??? ?
?? ??? ?P(rmutex);
?? ??? ?readcount--;
?? ??? ?if(readcount == 0) V(nrmutex);? //所有讀者退出,允許寫更新
?? ??? ?V(rmutex);
?? ?End
?? ?
?? ?writer begin
?? ??? ?P(rwmutex);??? //互斥后續其它讀者、寫者
?? ??? ?P(nrmutex);??? //如有讀者正在讀,等待所有讀者讀完
?? ??? ?寫更新;
?? ??? ?V(nrmutex);??? //允許后續新的第一個讀者進入后互斥寫操作 ?
?? ??? ?V(rwmutex);??? //允許后續新讀者及其它寫者
?? ?End ?
coend??

3. 利用pthread_cond_* & pthread_mutex_* 實現rw_lock

#include?<pthread.h>
#include?
<cstdlib>
#include?
<ctime>
#include?
<iostream>
using?namespace?std;

class?RWLock?{

private?:
????pthread_mutex_t?cnt_mutex;
????pthread_cond_t?rw_cond;
????
int?rd_cnt,?wr_cnt;

????RWLock(
const?RWLock&);
????RWLock
&?operator=?(const?RWLock&);

public?:
????RWLock():?rd_cnt(
0),wr_cnt(0)
????????{
????????????pthread_mutex_init(
&cnt_mutex,?NULL);
????????????pthread_cond_init(
&rw_cond,?NULL);
????????}

????
void?get_shared_lock()
????????{
????????????pthread_mutex_lock(
&cnt_mutex);
????????????
while?(wr_cnt?>0)
????????????????{
????????????????????pthread_cond_wait(
&rw_cond,&cnt_mutex);
????????????????}
????????????rd_cnt
++;
????????????pthread_mutex_unlock(
&cnt_mutex);
????????}

????
void?release_shared_lock()
????????{
????????????pthread_mutex_lock(
&cnt_mutex);
????????????rd_cnt
--;
????????????
if?(0?==?rd_cnt)
????????????????{
????????????????????pthread_cond_signal(
&rw_cond);
????????????????}
????????????pthread_mutex_unlock(
&cnt_mutex);
????????}

????
void?get_exclusive_lock()
????????{
????????????pthread_mutex_lock(
&cnt_mutex);
????????????
while?(rd_cnt+wr_cnt>0)
????????????????{
????????????????????pthread_cond_wait(
&rw_cond,&cnt_mutex);
????????????????}
????????????wr_cnt
++;
????????????pthread_mutex_unlock(
&cnt_mutex);
????????}

????
void?release_exclusive_lock()
????????{
????????????pthread_mutex_lock(
&cnt_mutex);
????????????wr_cnt
--;
????????????pthread_cond_broadcast(
&rw_cond);
????????????pthread_mutex_unlock(
&cnt_mutex);
????????}

????
~RWLock()
????????{
????????????pthread_mutex_destroy(
&cnt_mutex);
????????????pthread_cond_destroy(
&rw_cond);
????????}
};

class?Test
{

private?:????
????RWLock?
lock;
????
????
static?void*?shared_task_handler(void*?arg)
????????{
????????????Test
*?testptr?=?static_cast<Test*>(arg);

????????????testptr
->lock.get_shared_lock();
????????????
//do?the?shared?task?here
????????????testptr->lock.release_shared_lock();
????????}


????
static?void?*?exclusive_task_handler(void?*?arg)
????????{
????????????Test
*?testptr?=?static_cast<Test*>(arg);
????????????testptr
->lock.get_exclusive_lock();
????????????
//do?the?exclusive?task?here
????????????testptr->lock.release_exclusive_lock();
????????}

public?:
????typedef?
void*?(*ThreadFunc)?(void*);

????
void?start()
????????{
????????????srand(time(NULL));

????????????
const?int?THREADS_NO=rand()%100;
????????????pthread_t
*?threads?=?new?pthread_t[THREADS_NO];

????????????
for(int?i=0;?i<THREADS_NO;?i++)
????????????????{
????????????????????ThreadFunc?tmpfunc?
=?rand()%2??shared_task_handler?:?exclusive_task_handler;
????????????????????
if?(pthread_create(threads+i,NULL,tmpfunc,this))
????????????????????????{
????????????????????????????cerr?
<<?"pthread_create?fails"?<<?endl;
????????????????????????????exit(
1);
????????????????????????}
????????????????}

????????????
for(int?i=0;?i<THREADS_NO;?i++)
????????????????{
????????????????????pthread_join(threads[i],NULL);
????????????????}

????????????delete[]?threads;
????????}
};

int?main()
{
????Test?tmptest;
????tmptest.start();
}

--------------------------
參考:
Solaris 執行緒與同步機制之實例
Posix線程編程指南

posted on 2006-09-07 19:12 泡泡牛 閱讀(8945) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久国产精品一区二区三区四区| 制服丝袜亚洲播放| 久久久久在线观看| 精品成人在线| 亚洲第一精品夜夜躁人人躁 | 老司机免费视频一区二区| 亚洲午夜激情网页| 亚洲一区二区三区四区中文| 国产欧美1区2区3区| 牛牛精品成人免费视频| 欧美精品入口| 欧美影视一区| 麻豆精品国产91久久久久久| 一区二区三区国产在线| 亚洲尤物在线视频观看| 亚洲福利视频网| 宅男在线国产精品| 海角社区69精品视频| 亚洲国产导航| 国产热re99久久6国产精品| 欧美xxxx在线观看| 国产精品激情| 欧美激情一二三区| 国产美女扒开尿口久久久| 欧美激情视频一区二区三区免费| 欧美日韩一区二区在线| 免费成人av| 国产精品日韩欧美| 亚洲东热激情| 国产一区二区无遮挡| 99av国产精品欲麻豆| 在线免费精品视频| 亚洲一区综合| 亚洲视频一区二区| 免费成人美女女| 久久亚洲私人国产精品va| 国产精品福利久久久| 亚洲国产天堂久久综合网| 一区二区视频欧美| 午夜视频在线观看一区二区三区| 99成人精品| 欧美成人网在线| 在线精品国产欧美| 国产一区二区三区的电影| 日韩视频免费看| 亚洲国产精品成人va在线观看| 亚洲女人av| 亚洲一级特黄| 欧美三级午夜理伦三级中文幕 | 亚洲无线视频| 欧美激情在线播放| 亚洲国产成人porn| 在线电影一区| 久久久91精品国产一区二区精品| 欧美一区二区三区四区在线观看| 欧美视频免费在线观看| 日韩午夜在线视频| 亚洲午夜国产成人av电影男同| 欧美日韩国产色综合一二三四| 欧美激情一区| 99精品热视频| 欧美日韩在线电影| 亚洲午夜免费福利视频| 亚洲欧美国产77777| 国产精品久久久久久久电影| 一区二区三区国产| 亚洲欧美日韩精品一区二区 | 久久久夜精品| 欧美激情精品久久久久久蜜臀| 亚洲国产日韩综合一区| 免费成人小视频| 亚洲黄色免费网站| 中文av字幕一区| 国产精品美女诱惑| 欧美一区二区私人影院日本| 久久综合狠狠综合久久综合88| 一区二区三区中文在线观看 | 日韩亚洲在线| 亚洲欧美电影在线观看| 国产亚洲人成网站在线观看| 久久久久久999| 亚洲国产精品日韩| 亚洲午夜av| 国产在线观看一区| 免费在线观看日韩欧美| 一本色道久久综合亚洲二区三区| 性18欧美另类| 亚洲高清久久| 国产精品私房写真福利视频| 久久野战av| 一区二区三区高清在线观看| 久久先锋影音av| 一区二区三区福利| 狠狠色丁香久久婷婷综合丁香| 欧美波霸影院| 午夜电影亚洲| 亚洲激情成人网| 久久国产88| 这里只有精品视频在线| 国产在线欧美| 欧美三区在线视频| 久久婷婷综合激情| 亚洲永久在线| 亚洲美女免费精品视频在线观看| 久久精品国产第一区二区三区| 亚洲美女淫视频| 激情久久影院| 国产精品一区二区三区乱码| 久热爱精品视频线路一| 国产亚洲福利| 欧美日韩一本到| 久久久久一区二区三区| 亚洲欧美欧美一区二区三区| 91久久精品久久国产性色也91| 久久久久久电影| 亚洲永久免费av| 9人人澡人人爽人人精品| 黑人巨大精品欧美黑白配亚洲| 国产精品99免费看 | 美女精品视频一区| 亚洲欧美激情视频| 一区二区三区免费看| 亚洲国产日韩在线一区模特| 久久久亚洲精品一区二区三区| 亚洲欧美日韩久久精品| 一区二区三区高清在线| 99国产精品视频免费观看一公开| 亚洲国产成人精品久久久国产成人一区 | 久久综合九色九九| 久久国产精品久久久久久电车| 亚洲视频导航| 一区二区电影免费观看| 91久久国产综合久久蜜月精品 | 国产日韩精品视频一区二区三区| 欧美日韩视频在线一区二区观看视频| 欧美成在线视频| 欧美中文在线字幕| 亚洲欧美久久久| 亚洲免费视频观看| 午夜精品福利电影| 欧美亚洲视频一区二区| 欧美一区二区三区男人的天堂| 午夜久久资源| 久久精品亚洲精品| 狂野欧美激情性xxxx| 久久夜色精品一区| 欧美福利影院| 亚洲精一区二区三区| 一本久久综合亚洲鲁鲁| 亚洲视频成人| 欧美在线影院在线视频| 久久精品五月| 欧美国产精品人人做人人爱| 欧美色视频日本高清在线观看| 国产精品永久免费在线| 韩国成人精品a∨在线观看| 在线观看日韩av电影| 亚洲日韩欧美视频一区| 亚洲一区成人| 久久精品亚洲乱码伦伦中文| 欧美aⅴ99久久黑人专区| 亚洲激情啪啪| 亚洲资源在线观看| 久久综合九色欧美综合狠狠| 欧美片在线观看| 国产日韩精品一区观看| 亚洲黄一区二区三区| 亚洲无人区一区| 久久综合狠狠综合久久激情| 亚洲精品免费网站| 午夜国产精品视频| 欧美成熟视频| 国产一区二区三区久久悠悠色av| 最新精品在线| 久久国产视频网站| 亚洲青涩在线| 久久成人免费网| 欧美日韩hd| 在线免费日韩片| 亚洲欧美日韩国产中文 | 亚洲一区二区三| 久久久久国产成人精品亚洲午夜| 亚洲韩国日本中文字幕| 亚洲伦理网站| 欧美在线观看视频一区二区三区| 欧美69wwwcom| 亚洲综合成人在线| 欧美裸体一区二区三区| 韩国av一区二区| 午夜免费久久久久| 亚洲国产福利在线| 欧美中文字幕在线| 国产精品扒开腿做爽爽爽视频| 亚洲国产日韩欧美在线99| 性亚洲最疯狂xxxx高清| 亚洲欧洲中文日韩久久av乱码| 久久国内精品自在自线400部| 国产精品久久久一区二区三区| 亚洲日本电影| 欧美成人免费va影院高清|