• <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>
            隨筆 - 79  文章 - 58  trackbacks - 0
            <2007年6月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            1234567

            常用鏈接

            留言簿(9)

            隨筆分類

            隨筆檔案

            文章檔案

            相冊

            搜索

            •  

            積分與排名

            • 積分 - 295356
            • 排名 - 87

            最新評論

            閱讀排行榜

            評論排行榜

            問題提出:
            ??????? 在并發(fā)訪問的時候,允許并發(fā)訪問函數(shù)A,但是當(dāng)訪問函數(shù)A時不允許訪問函數(shù)B,同樣訪問函數(shù)B時不能函數(shù)A,即兩個函數(shù)之間是互斥的.如何才能獲得訪問A時的最大性能呢?

            解決方案(1):
            ???????假設(shè)多進(jìn)程環(huán)境下,一般選用PID作為可重入的重要條件,傳統(tǒng)實現(xiàn)如下:
            ?????? void lockpid(lock* p)
            ????? {
            ???????????? if(p->pid == getpid())
            ?????????????????? return;
            ???????????? else
            ??????????? {
            ??????????????????p->lock();
            ????????????}
            ????? }
            ??????本題解決也是借鑒如此,使用整數(shù) lockv = 0;作為兩函數(shù)互斥的根本,當(dāng)lockv>0時表示正在訪問函數(shù)A,<0時表示正在訪問函數(shù)B.具體實現(xiàn)如下:
            ??????函數(shù)A()
            ??????{
            ??????????? //臨界區(qū)
            ???????????{
            ??????????????????while(lockv < 0)
            ????????????????????????usleep(1);
            ??????????????????++lockv;

            ??????????? }
            ????????????
            ??????????? //do something ...

            ?????????? //臨界區(qū)
            ???????????{
            ??????????????????--lockv;
            ??????????? }???????
            ?????? }
            ???????
            ??????函數(shù)B()
            ??????{
            ??????????? //臨界區(qū)
            ???????????{
            ??????????????????while(lockv?> 0)
            ????????????????????????usleep(1);
            ??????????????????--lockv;

            ??????????? }
            ????????????
            ??????????? //do something ...

            ?????????? //臨界區(qū)
            ???????????{
            ??????????????????++lockv;
            ??????????? }???????
            ?????? }

            ??????缺點很明顯的,雖然在臨界區(qū)里面只有幾個機(jī)器指令,但并不能獲得最大的性能.如何優(yōu)化才能獲得函數(shù)A的最大性能呢?

            posted on 2006-11-18 11:44 merlinfang 閱讀(339) 評論(0)  編輯 收藏 引用

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久久久亚洲AV无码网站| 99热成人精品热久久669| 久久精品国产国产精品四凭| 99精品久久久久久久婷婷| 亚洲国产精品无码久久青草| 一级做a爰片久久毛片毛片| 热re99久久6国产精品免费| 国产精品视频久久久| 精品久久久久久无码人妻热| 国色天香久久久久久久小说| 蜜桃麻豆www久久| 精品多毛少妇人妻AV免费久久 | 久久午夜无码鲁丝片午夜精品| 国内精品伊人久久久久妇| 97久久天天综合色天天综合色hd | 国产一区二区三精品久久久无广告| 久久久久亚洲精品天堂久久久久久 | 97久久婷婷五月综合色d啪蜜芽| 久久久噜噜噜久久中文福利| 久久久久人妻一区精品| 99re久久精品国产首页2020| 亚洲国产日韩欧美综合久久| 亚洲国产精品久久久久久| 日本人妻丰满熟妇久久久久久| 久久久99精品成人片中文字幕| 久久国产色AV免费看| 久久精品国产亚洲av麻豆蜜芽 | 久久久久av无码免费网| 久久强奷乱码老熟女| 久久亚洲综合色一区二区三区 | 99久久精品国产一区二区三区| 久久午夜羞羞影院免费观看| 成人精品一区二区久久| 日产久久强奸免费的看| 久久精品国产2020| 2019久久久高清456| 蜜桃麻豆WWW久久囤产精品| 一本色综合久久| 亚洲人成电影网站久久| 三级三级久久三级久久| 亚洲人成电影网站久久|