• <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>
            隨筆-90  評論-947  文章-0  trackbacks-0

            最近有個東西,需要讀 XML 配置文件,于是用 msxml 做了。msxml 是基于 COM 的,使用之前需要 CoInitialize,使用之后需要 CoUninitialize。于是我寫成了:

            void foo()
            {
                CoInitialize(NULL);

                // Reading configuration

                CoUninitialize();
            }

            剛才我正樂此不彼的把類似這樣的東西改成:

            void foo()
            {
                CoInitialize(NULL);
                LOKI_ON_BLOCK_EXIT(CoUninitialize);

                // Reading configuration
            }

            前面的同事過來看到了,說,你不該在這里調用 CoInitialize 和 CoUninitialize。如果有的地方也在用 COM,你這里 CoUninitialize 一下,別的地方就會出錯了,上次的某個 Bug 就是。

            我狡辯道:我假定這里沒有多線程環境(實際上也是),并且約定別的地方用 COM 的時候調用 CoInitialize 時不要判斷返回值。

            同事:應該和大眾習慣保持一致,最好就是全項目最開始的時候 CoInitialize 一次,結束的時候 CoUninitialize 一次。

            我:我這里是較底層功能函數。

            同事:可以以文檔的方式注明,使用該模塊前必須自己 CoInitialize,使用完畢后自己 CoUninitialize。

            我:我只是想要用起來方便一點,用的時候不要有那么多先決條件和后置條件。再說,人家本來可以不知道我用了 COM,我這么一說明,就暴露了內部信息了不是?

            其實我被動搖了。

            各位大大,你們怎么處理呢?

            ------------------------------華麗的分割線(13:27 p.m. 增加)----------------------------------

            好,既然 CoInitialize 和 CoUninitialize 有引用計數機制,那么這個具體問題已經解決。

            那么,有沒有類似的成對使用的 API,會對進程全局產生影響的呢?如果有,在底層要用到的時候該怎么處理?

            posted on 2010-04-02 10:02 溪流 閱讀(25119) 評論(17)  編輯 收藏 引用 所屬分類: C++COM

            評論:
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 10:21 | 游客~~
            參照CoInitialize 的返回值,寫個類,在夠函數中根據前邊的返回值情況判斷是否調用 CoUninitialize  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 10:22 | 游客~~
            @游客~~
            是析構函數 剛才打錯  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 11:07 | 陳梓瀚(vczh)
            在某個cpp里面寫

            class FxxkCom
            {
            public:
            FxxkCom()
            {
            CoInitialize();
            }
            ~FxxkCom()
            {
            CoUninitialize();
            }
            } fxxkCom;  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 11:14 | WXX
            你不該在這里調用 CoInitialize 和 CoUninitialize。如果有的地方也在用 COM,你這里 CoUninitialize 一下,別的地方就會出錯了


            這句話不對,如果配對了應該就不會有問題。我的原則是這種調用盡量在線程的初始化和反初始化的時候做,其他時間盡量不做這種事情。  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 12:49 | 溪流
            @陳梓瀚(vczh)
            @WXX
            這個會不會影響其它線程?  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 12:52 | 溪流
            哦,好像只對當前線程起作用。。。那問題就沒有了,什么時候用什么時候調就可以了。

            有沒有會影響整個進程的這樣的成對的函數呢?  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 12:52 | berg
            放心好了,這兩個函數內部維護了引用計數,只要配對使用就好。  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 13:22 | 溪流
            @berg

            果然!測試OK~~~  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 13:56 | Jakcie
            類似于這樣的初始化,的確應該放在整個工程的一開始和最后比較好。
            例如,CoInitializeEx,OleInitialize,WSAStartup之類的,一開始就調用。最后釋放。一開始如果調用不成功,也比較好處理。  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 15:56 | 溪流
            @Jakcie
            如果我在寫庫/底層函數呢?  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 16:02 | OwnWaterloo
            我也這么干過:

            class C{
            C() {
            CoInit()
            }
            ~C() {
            CoUnit()
            }
            ...
            };

            為的也是讓其他代碼干凈一些, 不要引入那些丑陋的頭文件以及看到COM這么丑陋的東西。

            全局數據初始化有不同的設計方法。
            如果內部有引用技術, 就可以這么干。
            如果沒有, 就告訴C的使用者, 使用前需要怎樣, 使用后又怎樣。
              回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-02 19:02 | 飛鴿傳書
            最好在構造與析構,可以保證他在先于控件創建,后于控件銷毀。  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2010-04-13 02:27 | 欲三更
            這個是引用計數的,沒問題。
            想想看,如果這個函數沒有引用計數,那會帶來無數的問題。  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2011-02-28 10:24 | gggg
            我測試過,是沒有關系的,只要兩個東西配對,你想怎么調用都可以  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2011-03-08 16:17 | 溪流
            @fixdot
            對,當時也是這樣的問題。也是原因不明。可是既然原因不明,那么作為論據其實有問題的。如果這兩個函數確實有引用計數的,那么應該提倡用時CoInitialize,用完馬上CoUninitialize。除非能夠說出“一個進程里最好只調用一次”的道理。  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2011-03-08 18:50 | 溪流
            @fixdot
            為什么刪除了?  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2011-03-31 09:56 | Wallace
            @溪流
            我的程序里面怎么不行,一個是EXCEL的類,其構造函數和析構函數里有相關的初始化和釋放代碼,另一個是ADO操作數據庫的類,也有一對代碼,可是只要一輸出過EXCEL,那個ADO查詢數據庫的類就用不了。  回復  更多評論
              
            # re: CoInitialize 和 CoUninitialize 的調用時機問題 2011-10-10 10:39 | daixi
            你的同事說的是對的,最好是每個線程的開始一次CoInitialize,退出的時候一次CoUninitialize。否則的確會出一些亂七八糟的問題。曾經在這個事情上吃過虧,最后的解決辦法就是只CoInitialize,不調CoUninitialize。哈哈哈哈。。。  回復  更多評論
              
            久久综合久久综合久久综合| 亚洲午夜久久影院| 精品久久久久久国产| 日韩乱码人妻无码中文字幕久久| 亚洲va久久久噜噜噜久久男同| 国产精品久久久久天天影视| 久久国产午夜精品一区二区三区| 要久久爱在线免费观看| 99re这里只有精品热久久| 人妻精品久久久久中文字幕| 亚洲精品白浆高清久久久久久| 亚洲国产精品久久久久| 人人狠狠综合久久88成人| 精品久久久久久久久久久久久久久| 伊人久久大香线焦AV综合影院| 国产精品一久久香蕉国产线看观看 | 久久亚洲国产成人精品无码区| 亚洲va久久久久| 97久久精品无码一区二区| 久久人人爽人人爽人人片AV东京热| 久久婷婷成人综合色综合| 亚洲精品美女久久久久99小说| 韩国三级大全久久网站| 国产69精品久久久久9999APGF| 国产精品免费久久久久影院| 精品综合久久久久久888蜜芽| 久久亚洲AV无码西西人体| 久久久久免费精品国产| 久久婷婷五月综合国产尤物app| 久久人人爽人人澡人人高潮AV | 2021久久精品免费观看| 久久高清一级毛片| 精品国产一区二区三区久久蜜臀| 国产∨亚洲V天堂无码久久久| 久久精品99久久香蕉国产色戒 | 久久久久久久久久免免费精品| 久久天天躁狠狠躁夜夜网站| 久久婷婷五月综合97色| 精品久久久久久无码专区| 成人免费网站久久久| 国产精品毛片久久久久久久|