• <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 
            亚洲成色www久久网站夜月| 亚洲熟妇无码另类久久久| 国产精品无码久久综合网| 久久久WWW成人| 看久久久久久a级毛片| 久久99精品国产麻豆蜜芽| 亚洲AV无码久久精品成人| 精品久久久久久99人妻| 精品久久久中文字幕人妻| 99久久99久久精品国产片| 日韩欧美亚洲综合久久| 日本道色综合久久影院| 亚洲AV无码久久| 久久丫忘忧草产品| 品成人欧美大片久久国产欧美| 日韩精品久久久久久久电影蜜臀| 成人亚洲欧美久久久久| 97久久精品午夜一区二区| 久久午夜福利无码1000合集| 精品久久人人爽天天玩人人妻| 久久人人爽人人爽人人片av高请 | 久久青青草原亚洲av无码app| 91久久精品无码一区二区毛片| 久久亚洲精品成人无码网站| 久久久久国产精品嫩草影院| 久久久精品午夜免费不卡| 性欧美大战久久久久久久久| 久久久久亚洲AV无码专区网站| 99久久综合狠狠综合久久| 人人狠狠综合久久亚洲88| 久久精品国产亚洲沈樵| 日产精品久久久久久久性色| 亚洲国产综合久久天堂| 久久综合亚洲色HEZYO社区| 热综合一本伊人久久精品| 久久精品99无色码中文字幕| 久久精品国产精品亜洲毛片| 人妻丰满?V无码久久不卡| 欧美精品国产综合久久| 久久精品人人做人人爽97| 99久久国产热无码精品免费|