• <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 
            久久精品无码一区二区无码| 色噜噜狠狠先锋影音久久| 97久久精品人人做人人爽| 久久99精品久久久久久水蜜桃| 久久久久国产精品麻豆AR影院| 久久人人爽人人爽AV片| 亚洲AV日韩精品久久久久久久| 99久久久国产精品免费无卡顿| 久久精品国产影库免费看 | 亚洲色欲久久久综合网| 久久久女人与动物群交毛片| 久久久久无码精品| 久久99久久99精品免视看动漫| 88久久精品无码一区二区毛片 | 国内精品伊人久久久影院| 狠狠综合久久AV一区二区三区| 久久er热视频在这里精品| 色狠狠久久综合网| 亚洲国产精品热久久| 精品久久久无码21p发布| 伊人久久免费视频| 亚洲精品乱码久久久久久按摩| 久久久精品波多野结衣| 99麻豆久久久国产精品免费 | 免费一级做a爰片久久毛片潮 | 中文字幕无码免费久久| 狠狠久久综合伊人不卡| 99久久综合狠狠综合久久止| 一本色道久久88—综合亚洲精品| 久久99精品久久久久久噜噜| 国产精品美女久久久久网| 久久精品国产亚洲av水果派| 久久精品国产99久久久古代| 亚洲精品成人网久久久久久| 国产亚洲色婷婷久久99精品91 | 久久精品中文无码资源站 | 久久国产精品-久久精品| 久久久久久久97| 久久AV高清无码| 久久线看观看精品香蕉国产| 国产精品毛片久久久久久久|