• <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>

            勤能補(bǔ)拙,Expter

            成都游戲Coder,記錄游戲開發(fā)過程的筆記和心得!

            一個(gè)關(guān)于vector在讀取和壓入技巧性的效率優(yōu)化

                     在多線程過程中,對于線程間的數(shù)據(jù)共享同步問題,具體針對多線程需要對一個(gè)Vector進(jìn)行讀與寫的操作,不考慮緩沖區(qū)的操作,一般情況下為了保證穩(wěn)定性的同時(shí)在讀寫的時(shí)候都要進(jìn)行加鎖,其實(shí)可以通過一個(gè)技巧,就是通過一個(gè)臨時(shí)變量在寫數(shù)據(jù)的時(shí)候把第一個(gè)值付給臨時(shí)變量,那么在讀取數(shù)據(jù)的線程中會(huì)直接讀取臨時(shí)變量,此時(shí)只需要加鎖一次即可。



                     我寫了一個(gè)測試?yán)樱褪顷P(guān)于開3個(gè)讀,寫,刪的操作。。。一般情況進(jìn)行加鎖,與通過通過臨時(shí)變量來減少一次加鎖速度與效率明顯低于后者。
                     針對1000000個(gè)數(shù)據(jù)的操作,操作1比操作2快2倍以上。


                     下面是我的測試代碼,簡單。。。只是為了說明問題
                     
            /Files/expter/l_thread.rar
                    

            posted on 2009-08-14 23:52 expter 閱讀(2230) 評論(5)  編輯 收藏 引用

            評論

            # re: 一個(gè)關(guān)于vector在讀取和壓入技巧性的效率優(yōu)化 2009-08-15 01:47 pear_li

            說實(shí)話,樓主這個(gè)想法不怎么樣
            看過你的代碼就更加確信了這一想法
            理由如下:
            既然要滿足讀寫,就要考慮讀寫值的實(shí)時(shí),臨時(shí)變量本身就不能確保當(dāng)前讀寫值的實(shí)時(shí)性(且不說樓主對tmp和flag的操作連最基本的volatile都沒有加),你的想法只是考慮變量讀寫的安全性,而忽略實(shí)時(shí)性

            公認(rèn)比較安全快速的做法:使用共享鎖,提高讀取效率

              回復(fù)  更多評論   

            # re: 一個(gè)關(guān)于vector在讀取和壓入技巧性的效率優(yōu)化 2009-08-15 06:38 空明流轉(zhuǎn)

            樓主的思路,和Lock-free有點(diǎn)接近,建議去參考一下。。。  回復(fù)  更多評論   

            # re: 一個(gè)關(guān)于vector在讀取和壓入技巧性的效率優(yōu)化 2009-08-15 16:42 expter

            @pear_li
            我只是 為了說明這樣一個(gè)方法,可能在有些地方效率會(huì)更低,而且程序我只是一個(gè)為了測試而已,估計(jì)沒有考慮跟多,謝謝指出。  回復(fù)  更多評論   

            # re: 一個(gè)關(guān)于vector在讀取和壓入技巧性的效率優(yōu)化 2009-08-15 16:53 李侃

            同意2樓,共享資源傳統(tǒng)的方式最好使用共享鎖和排他鎖,分而治之,可以參考讀寫鎖的實(shí)現(xiàn)方法win32下單進(jìn)程內(nèi)建議使用用戶模式,interlock系列函數(shù)足以

            鎖無關(guān)數(shù)據(jù)結(jié)構(gòu)我還沒找到很好的解決方案  回復(fù)  更多評論   

            # re: 一個(gè)關(guān)于vector在讀取和壓入技巧性的效率優(yōu)化 2009-08-20 21:28 hlysh

            常常關(guān)注你的blog,每篇文章都很好支持!  回復(fù)  更多評論   

            久久久久亚洲精品日久生情 | 久久久久亚洲AV片无码下载蜜桃| 无码人妻少妇久久中文字幕| 亚洲人成网站999久久久综合| 久久久黄色大片| 精品久久久久久无码中文字幕一区| 精品国产VA久久久久久久冰| 色综合久久最新中文字幕| 久久久久久午夜精品| 久久九九全国免费| 精产国品久久一二三产区区别 | 久久99久国产麻精品66| 久久久久久国产精品无码超碰| 久久免费小视频| 无码人妻久久一区二区三区| 国产三级精品久久| 久久久久人妻精品一区| 久久亚洲精品无码aⅴ大香| 99久久国产综合精品成人影院 | 久久久国产精品福利免费| 久久人妻无码中文字幕| 99热都是精品久久久久久| 一本久道久久综合狠狠爱| 午夜精品久久影院蜜桃| 情人伊人久久综合亚洲| 国产午夜免费高清久久影院| 国产69精品久久久久APP下载| 久久99精品免费一区二区| 99国产精品久久久久久久成人热| 99久久夜色精品国产网站| 亚洲国产成人久久综合碰| 精品久久久久久无码人妻热| 99久久99久久精品国产片| 91亚洲国产成人久久精品| 久久精品国产亚洲综合色| 粉嫩小泬无遮挡久久久久久| 狠狠88综合久久久久综合网| 波多野结衣中文字幕久久 | 国产色综合久久无码有码| 久久久亚洲AV波多野结衣| 无码国产69精品久久久久网站|