• <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 溪流 閱讀(25118) 評論(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。哈哈哈哈。。。  回復  更多評論
              
            久久久久99精品成人片| 性欧美大战久久久久久久久| 国产日韩久久免费影院| 久久久不卡国产精品一区二区 | 日韩美女18网站久久精品| 久久久国产亚洲精品| 国产精品久久久久aaaa| 午夜精品久久影院蜜桃| 成人久久精品一区二区三区| 精品乱码久久久久久夜夜嗨| 亚洲日韩中文无码久久| 日本福利片国产午夜久久| 综合网日日天干夜夜久久 | 国产一区二区精品久久凹凸| 久久精品国产99国产精品亚洲| 色综合久久最新中文字幕| 亚洲精品乱码久久久久久按摩 | 亚洲国产综合久久天堂| 久久国产精品国产自线拍免费| 思思久久99热只有频精品66| 青青草国产精品久久久久| 亚洲女久久久噜噜噜熟女| 少妇久久久久久被弄到高潮| 99久久精品免费| 国产亚洲精品美女久久久| 久久国产欧美日韩精品| 欧洲国产伦久久久久久久| 99久久夜色精品国产网站| 69久久精品无码一区二区| 亚洲国产精品无码久久久秋霞2| 亚洲欧美国产精品专区久久| 狠狠久久亚洲欧美专区| 久久99精品久久久久婷婷| 亚洲AV无码一区东京热久久| 久久综合久久美利坚合众国| 思思久久好好热精品国产| 国产午夜精品久久久久九九| 久久精品国产91久久麻豆自制| 久久久久久夜精品精品免费啦| 亚洲αv久久久噜噜噜噜噜| 精品国产乱码久久久久软件|