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

            hdqqq

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              35 隨筆 :: 0 文章 :: 104 評論 :: 0 Trackbacks
            共2頁: 1 2 
            hThread[i] = CreateThread(NULL, 0, helloFunc, (LPVOID)i, 0, NULL);
            上面這句是有問題的,因為CreateThread返回時候,并不保證線程已經啟動了,所以進入下一個循環后i就被修改,導致線程取得了錯誤的參數.
            這段代碼是創建微軟xml com對象的,程序就這里用了com接口, 看來對異常處理的還是不夠.
            測試還是不夠,讓兄弟們見笑了.
            有可能.
            所以還需要一個附加機制來記錄程序的運行棧,可以象這樣
            #ifdef _DEBUG
            struct _run_stack {
            static std::stack< std::string > _debug_stack;
            };
            #endif

            template<typename a>
            std::string make_debug(a pa)
            {
            stringstream ls;
            ls << pa << std::endl;
            return ls.str();
            }

            template<typename a,typename b>
            std::string make_debug(a pa, b pb)
            {
            stringstream ls;
            ls << pa << " " << pb << std::endl;
            return ls.str();
            }
            ...按需要擴充

            struct debug_help {

            template<typename a>
            debug_help(a pa) {
            _run_stack::_debug_stack.push(make_debug(pa));
            }
            template<typename a, typename b>
            debug_help(a pa,b pb) {
            _run_stack::_debug_stack.push(make_debug(pa,pb));
            }
            ...按需要擴充

            ~debug_help() {
            _run_stack::_debug_stack.pop();
            }
            };

            -----
            實際使用
            void excepti_func
            {
            #ifdef _DEBUG
            debug_help(__FILE__,__LINE__);
            #endif
            ....
            }

            或者
            void _fd
            {
            int i,j,k;
            for (i = 0; i< 100; i__) {
            debug_help(__FILE__,__LINE__, i);
            for (j = 0; j < 100; j++) {
            debug_help(__FILE__,__LINE__, j);
            for(k = 0; k < 100; k++) {
            debug_help(__FILE__,__LINE__, k);
            }
            }
            }
            }

            出現異常的時候,只要把_run_stack::_debug_stack顯示出來看看就可以了.也可以通過條件編譯,在最終release中將其去掉.
            這個其實使用了編譯器內建的__FILE__,和 __LINE__宏,在編譯器就確定了的,上面的代碼來說,如果在某個函數中處理了異常并顯示信息,以后不管這個函數在那里被調用,顯示的異常信息都是一樣的. 象下面

            void excep_handle(...)
            {
            try {
            ...
            THROW_EX( " there is a exception\n " );
            } catch (more_exception & e) {
            SET_CATCH_POS(e);
            std::cout << e;
            }
            }

            而調用的函數是這樣的
            void test()
            {
            int i,j,k;
            for (i = 0; i < 100; i++) {
            excep_handle(...)
            for (j = 0; j < 100; j++) {
            excep_handle(...)
            for(k = 0; k < 100; k++) {
            excep_handle(...)
            }
            }
            }
            }

            上面的代碼,不管在那層循環的調用中,異常彈出的都是同一個文件和同一個行數無法知道具體是在那一層出現的異常.
            re: zlib 壓縮管道 hdqqq 2006-11-22 16:28
            @ar4ever
            你可以在zlib的官方網站下載它的壓縮包,以zlib1.2.3為例,解壓縮后,其目錄下的project子目錄下,有vc 6 的工程文件,有8個項目,分別是匯編和c代碼的dll和lib輸出的工程,你編譯全部后,把你要用的lib 和頭文件 zlib.h 放到vc的include 和lib設置中就可以了.
            共2頁: 1 2 
            亚洲精品午夜国产VA久久成人| 久久人人添人人爽添人人片牛牛| 久久精品国产精品亚洲| 国产婷婷成人久久Av免费高清| 日产精品久久久久久久性色| 欧美熟妇另类久久久久久不卡 | 久久99国产精品一区二区| jizzjizz国产精品久久| 久久九九青青国产精品| 午夜精品久久影院蜜桃| 日产精品久久久久久久| 一级女性全黄久久生活片免费| 91久久精品91久久性色| 日批日出水久久亚洲精品tv| A狠狠久久蜜臀婷色中文网| 久久免费观看视频| 久久久黄片| 亚洲伊人久久综合影院| 精品久久久久一区二区三区| 久久亚洲精品人成综合网| 午夜精品久久久内射近拍高清 | 久久婷婷五月综合国产尤物app | 国产亚洲精久久久久久无码AV| 久久久久久精品无码人妻| 久久精品一区二区三区中文字幕| 波多野结衣中文字幕久久| 人妻精品久久久久中文字幕69| 国产精品99久久久久久宅男小说| 久久性精品| 人妻无码久久一区二区三区免费| 久久天天躁狠狠躁夜夜网站| 久久Av无码精品人妻系列| 狠狠久久亚洲欧美专区| 无码任你躁久久久久久久| 色偷偷91久久综合噜噜噜噜| 久久婷婷国产剧情内射白浆 | 亚洲中文字幕无码久久综合网| 一本久久a久久精品亚洲| 久久久精品人妻无码专区不卡 | 蜜桃麻豆WWW久久囤产精品| 久久精品一本到99热免费|