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

            fengyue

            CString不是線程安全的

            我們用MFC開發時經常會用到CString類,無可否認,CString類是很好用,但很少人注意到CString類不是線程安全的。一般地,界面編程都是在主線程,很少用到多線程,所以不會遇到什么問題。但是,當我們多個線程同時操作同一個CString類型變量時,就可能會出現內存地址錯誤,最終導致進程異常退出。內存錯誤導致的問題也很難調查,通常導致內存錯誤的地方沒有馬上報異常,而且在程序的其他地方才捕獲異常。
            CString類的Debug版本和Release版本不完全一樣,Debug版本則直接分配(MFC在Debug版本有內存管理,主要是為了排錯,內存泄漏等),CString類在Release版本會使用定長內存管理(CFixedAlloc類),主要管理是4個長度的內存,如下:
            1AFX_STATIC CFixedAlloc _afxAlloc64(ROUND4(65*sizeof(TCHAR)+sizeof(CStringData)));
            2AFX_STATIC CFixedAlloc _afxAlloc128(ROUND4(129*sizeof(TCHAR)+sizeof(CStringData)));
            3AFX_STATIC CFixedAlloc _afxAlloc256(ROUND4(257*sizeof(TCHAR)+sizeof(CStringData)));
            4AFX_STATIC CFixedAlloc _afxAlloc512(ROUND4(513*sizeof(TCHAR)+sizeof(CStringData)));
            這樣做應該是防止內存碎片和提高效率,由于CString類都會重用分配的定長內存,所以一般異常的地方大多數也是在CString操作的地方。有興趣可以看看CString類的實現。
            避免這樣的問題最簡單的辦法就是加鎖或者不用CString類。加鎖用臨界區就可以,實現比較簡單,在這里不多說。

            posted on 2011-11-24 10:58 風悅 閱讀(2949) 評論(5)  編輯 收藏 引用 所屬分類: C/C++

            Feedback

            # re: CString不是線程安全的 2011-11-24 11:37 陳梓瀚(vczh)

            用std::wstring  回復  更多評論   

            # re: CString不是線程安全的 2011-11-24 11:51 mtian

            MFC,STL這種類庫一般都不是線程安全的,畢竟內部加鎖是會降低效率的  回復  更多評論   

            # re: CString不是線程安全的[未登錄] 2011-11-24 11:59 陳梓瀚(vczh)

            @mtian
            但是cout是線程安全的——不過如果非要用一個線程安全的string,就得學C#,它的string是生成后不可修改的。哪怕是你insert,都會搞出一個新string。不過因為有CLR的關系,這個效率比C++的那種傳統模式還要好。  回復  更多評論   

            # re: CString不是線程安全的 2011-11-26 23:59 Benjamin

            http://msdn.microsoft.com/zh-cn/library/cc438572(v=VS.71).aspx,MSDN很早都有說明:“對于大量使用字符串的代碼(或多線程代碼),默認的內存管理器可能就無法理想地工作。”  回復  更多評論   

            # re: CString不是線程安全的 2011-11-29 22:37 王繼

            std::wstring一樣線程不安全,更郁悶的是VS自帶的WTL,居然不能在dll函數參數中傳來傳去,否則內存泄露.boost可以的.  回復  更多評論   

            国产91久久综合| 丰满少妇高潮惨叫久久久| 国产香蕉97碰碰久久人人| 亚洲国产精品婷婷久久| 久久影院午夜理论片无码| 久久亚洲AV成人无码软件| 精品久久香蕉国产线看观看亚洲| 久久精品国产72国产精福利| 国产精品久久久久久久久软件| 久久亚洲欧美国产精品| 精品久久久久中文字幕一区| 亚洲精品无码成人片久久| 激情五月综合综合久久69| 无码专区久久综合久中文字幕| 伊人久久综合热线大杳蕉下载| 亚洲AV伊人久久青青草原| 97r久久精品国产99国产精| 久久婷婷五月综合97色直播| 久久夜色精品国产亚洲| 久久99热这里只有精品国产| 久久国产福利免费| 99久久综合狠狠综合久久| 久久超碰97人人做人人爱| 人人狠狠综合久久亚洲| 国产精品无码久久久久| 久久亚洲高清观看| 欧美久久综合性欧美| 久久AV高清无码| 久久久亚洲AV波多野结衣| 一级a性色生活片久久无| 久久精品夜色噜噜亚洲A∨| 狠狠色丁香婷婷久久综合不卡| 久久久久免费看成人影片| 一本色道久久HEZYO无码| 久久狠狠爱亚洲综合影院| 久久天天躁狠狠躁夜夜2020一| 亚洲精品97久久中文字幕无码| 久久久精品久久久久特色影视| 国产福利电影一区二区三区久久老子无码午夜伦不 | 无码人妻精品一区二区三区久久 | 久久99精品久久久久久hb无码|