• <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 
            国产99久久久国产精品小说| 99久久免费国产特黄| 精品国产婷婷久久久| 久久精品二区| 国内精品久久久久久久久电影网| 日本五月天婷久久网站| 久久久久亚洲精品日久生情| 亚洲AV无码成人网站久久精品大| 久久精品国产亚洲av麻豆色欲| 波多野结衣中文字幕久久| 国产高潮国产高潮久久久91| 久久久久久国产精品美女| 狠狠干狠狠久久| 久久这里都是精品| 欧美激情精品久久久久| 国产毛片欧美毛片久久久| 久久国产精品久久| 久久久午夜精品福利内容| 91精品国产高清久久久久久io| 日韩欧美亚洲国产精品字幕久久久 | 狠狠色丁香久久综合五月| 免费精品久久久久久中文字幕| 久久久久无码精品国产不卡| 欧美日韩成人精品久久久免费看| jizzjizz国产精品久久| 久久久午夜精品| 欧美与黑人午夜性猛交久久久| 69国产成人综合久久精品| 久久久久亚洲AV片无码下载蜜桃| 18岁日韩内射颜射午夜久久成人| 日韩精品无码久久久久久| 亚洲欧美一区二区三区久久| 九九久久精品无码专区| 国产成人精品久久免费动漫| 久久久久亚洲Av无码专| 午夜精品久久久久久99热| 精品综合久久久久久98| 狠狠色丁香久久婷婷综合图片| 性做久久久久久久久老女人| 欧美一区二区久久精品| 久久精品国产亚洲av麻豆图片|