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

<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>
            99热免费精品| 一本色道久久综合亚洲精品小说 | 黄色成人在线网址| 国产乱码精品1区2区3区| 国产精品区免费视频| 国产精品视频免费观看| 国产欧美视频在线观看| 国产一区视频在线看| 一区二区三区在线免费观看| 在线观看中文字幕不卡| 亚洲理伦电影| 销魂美女一区二区三区视频在线| 亚洲午夜av电影| 欧美一级夜夜爽| 老司机亚洲精品| 亚洲高清视频一区| 亚洲国产天堂久久综合| 亚洲午夜黄色| 久久综合影音| 欧美日韩综合在线| 国内揄拍国内精品久久| 亚洲免费电影在线| 欧美一区二区高清在线观看| 免费亚洲视频| 亚洲一级在线观看| 欧美成人国产一区二区| 国产精品午夜国产小视频| 91久久国产综合久久| 午夜欧美精品| 亚洲精品国产精品国自产在线| 午夜欧美大片免费观看| 欧美精品一区二区在线观看| 国内视频一区| 亚洲欧美欧美一区二区三区| 欧美激情导航| 亚洲欧美综合v| 欧美日韩在线观看视频| 在线观看精品一区| 午夜精品影院| 99视频精品全部免费在线| 美国十次成人| 国产日韩欧美在线视频观看| 亚洲无线一线二线三线区别av| 欧美一区二区三区成人| 亚洲欧洲精品一区二区三区 | 欧美理论视频| 欧美系列精品| 亚洲伦理网站| 欧美+日本+国产+在线a∨观看| 亚洲免费视频网站| 欧美三级网址| 在线视频免费在线观看一区二区| 欧美电影美腿模特1979在线看| 性做久久久久久免费观看欧美| 国产精品v片在线观看不卡| 亚洲精品永久免费| 亚洲国产精品久久91精品| 久久亚洲私人国产精品va| 极品少妇一区二区| 久久久久国产精品厨房| 欧美影院久久久| 国产一区观看| 美日韩在线观看| 久久综合亚州| 亚洲精品中文字幕在线| 亚洲黄色av| 欧美日韩国产免费| 亚洲一二三区精品| 亚洲一区二区三区免费视频| 国产精品亚洲综合| 久久九九精品99国产精品| 久久激情视频| 在线国产亚洲欧美| 欧美激情aaaa| 欧美日韩精品| 午夜一区二区三区不卡视频| 欧美一区二区大片| 尤物在线精品| 亚洲精品国产精品国自产观看| 欧美午夜久久| 久久久久久久久久久久久久一区| 欧美在线视频播放| 亚洲国产精品热久久| 亚洲欧洲午夜| 国产精品蜜臀在线观看| 亚洲欧美日韩国产| 久久不射网站| 日韩小视频在线观看专区| 亚洲视频一起| 精品av久久707| 亚洲三级性片| 国产一区二区在线观看免费| 亚洲大片在线观看| 国产精品久久久久久久久婷婷| 欧美主播一区二区三区| 欧美成人免费小视频| 亚洲综合久久久久| 久久免费的精品国产v∧| avtt综合网| 久久久久国产一区二区| 久久亚洲综合网| 欧美在线电影| 亚洲精品一二区| 亚洲欧美日韩国产综合精品二区| 在线精品高清中文字幕| 亚洲婷婷综合色高清在线| 亚洲第一色在线| 亚洲一区二区三区三| 亚洲美女在线国产| 久久久久久久久蜜桃| 亚洲尤物精选| 欧美激情小视频| 噜噜噜久久亚洲精品国产品小说| 欧美日韩精品伦理作品在线免费观看| 久久精品欧美| 国产精品久久久久久久久| 欧美激情女人20p| 国产一区二区欧美| 99亚洲一区二区| 亚洲日本久久| 久久一区二区三区超碰国产精品 | 久久国产精品一区二区三区| 欧美激情按摩在线| 老色鬼久久亚洲一区二区| 国产精品美女| 99精品99| 一本色道久久综合亚洲精品按摩| 久久国产精品网站| 欧美在线播放高清精品| 欧美午夜片欧美片在线观看| 最新日韩中文字幕| 亚洲精品国精品久久99热| 久久免费黄色| 模特精品在线| 亚洲国产精品电影在线观看| 久久久蜜臀国产一区二区| 久久人人爽人人爽| 国产亚洲成精品久久| 亚洲综合欧美| 久久国产精品高清| 国产主播一区| 久久九九热免费视频| 久久亚洲欧美国产精品乐播| 好吊成人免视频| 久久五月激情| 欧美激情亚洲国产| 亚洲精品视频免费观看| 欧美美女视频| 一区二区三区精密机械公司 | 伊人久久大香线| 久热国产精品视频| 欧美好吊妞视频| 99精品欧美一区二区三区综合在线 | 国产乱人伦精品一区二区| 午夜国产精品视频| 久久一本综合频道| 亚洲黄一区二区三区| 欧美另类视频在线| 亚洲桃花岛网站| 久久精品视频va| 亚洲高清视频的网址| 国产视频在线观看一区| 99re8这里有精品热视频免费| 宅男噜噜噜66国产日韩在线观看| 欧美午夜理伦三级在线观看| 香蕉久久国产| 欧美成年人网站| 99精品热视频只有精品10| 国产精品高潮粉嫩av| 欧美伊人久久久久久午夜久久久久 | 亚洲国产精品成人一区二区| 欧美高清在线观看| 亚洲无线视频| 免费不卡在线观看av| 夜夜嗨av一区二区三区四区| 国产精品一区二区三区观看 | 免费成人黄色| 在线视频精品| 毛片基地黄久久久久久天堂| 亚洲视频在线看| 极品日韩av| 国产精品一级在线| 欧美ed2k| 欧美在线观看一区二区| 亚洲日韩欧美视频一区| 久久免费黄色| 午夜久久黄色| 一本久久青青| 亚洲国产成人精品女人久久久 | 日韩视频一区二区| 国产手机视频一区二区| 欧美日韩播放| 免费不卡中文字幕视频| 欧美综合二区| 亚洲午夜激情| 一区二区欧美日韩| 亚洲激情在线播放| 欧美成人午夜免费视在线看片| 欧美一区二区三区四区高清 | 欧美午夜一区二区|