• <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>
            隨筆 - 96  文章 - 255  trackbacks - 0
            <2010年6月>
            303112345
            6789101112
            13141516171819
            20212223242526
            27282930123
            45678910

            E-mail:zbln426@163.com QQ:85132383 長期尋找對戰略游戲感興趣的合作伙伴。

            常用鏈接

            留言簿(21)

            隨筆分類

            隨筆檔案

            SDL相關網站

            我的個人網頁

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 492222
            • 排名 - 38

            最新評論

            閱讀排行榜

            評論排行榜

            以下以win32平臺為例。我們先看一個非多線程的程序:
            #include <iostream>
            #include 
            <windows.h>

            DWORD WINAPI thread_func(LPVOID pN)
            {
                
            for (int i = 0; i < *((int*)pN); ++i) {
                    std::cout 
            << i+1 << "\t";
                }
                std::cout 
            << std::endl;
                
            throw "ok.";

                std::cout 
            << "thread_func() done." << std::endl;
                
            return 0;
            }

            int main(int argc, char* argv[])
            {
                
            int n = 5;

                
            try{
                thread_func((LPVOID)
            &n);
                Sleep(
            2000);
                }
                
            catch (const char* s) {
                    std::cerr 
            << s << std::endl;
                    exit(
            1);
                }

                std::cout 
            << "main() done." << std::endl;

                
            return 0;
            }
            可以看到,函數thread_func()可以正確的拋出異常并被main()的catch捕捉。但是,如果用一個新線程來運行thread_func()會出現什么情況呢?
            #include <iostream>
            #include 
            <windows.h>

            DWORD WINAPI thread_func(LPVOID pN)
            {
                
            for (int i = 0; i < *((int*)pN); ++i) {
                    std::cout 
            << i+1 << "\t";
                }
                std::cout 
            << std::endl;
                
            throw "ok.";

                std::cout 
            << "thread_func() done." << std::endl;
                
            return 0;
            }

            int main(int argc, char* argv[])
            {
                HANDLE hThrd;
                DWORD thrdId;
                
            int n = 5;

                
            try{
                hThrd 
            = CreateThread(    NULL,
                                        
            0,
                                        thread_func,
                                        (LPVOID)
            &n,
                                        
            0,
                                        
            &thrdId);
                Sleep(
            2000);
                }
                
            catch (const char* s) {
                    std::cerr 
            << s << std::endl;
                    exit(
            1);
                }

                std::cout 
            << "main() done." << std::endl;

                
            return 0;
            }
            很不幸,這個程序編譯的時候是可以通過的,但是運行時出錯:
            1       2       3       4       5

            This application has requested the Runtime to terminate it 
            in an unusual way.
            Please contact the application
            's support team for more information.
            請按任意鍵繼續. . .
            而且同時會有一個運行時錯誤的提示。事實上,這個錯誤提示意味著程序在沒有發現try{}的時候看到了throw。
            通過試驗,我發現系統(這里是win32)不能將CreateThread()所產生的線程歸結到try{}中。更加嚴重的情況是,即使用一個函數囊括了整個程序,然后try這個函數,其他線程依然脫離了這個try。
            所以,一個解決方法是,凡是遇到新的線程,必須在新線程中重新寫異常處理。不然,就如google代碼標準里所說的那樣,不使用C++的異常機制。畢竟C++沒有定義多線程的標準,所以也就無從說起多線程中異常處理的標準。
            最后附上在新線程寫異常處理的參考:
            #include <iostream>
            #include 
            <windows.h>

            DWORD WINAPI thread_func(LPVOID pN)
            {
                
            try{
                
            for (int i = 0; i < *((int*)pN); ++i) {
                    std::cout 
            << i+1 << "\t";
                }
                std::cout 
            << std::endl;
                
            throw "ok.";
                }
                
            catch (const char* s) {
                    std::cerr 
            << s << std::endl;
                    exit(
            1);
                }

                std::cout 
            << "thread_func() done." << std::endl;
                
            return 0;
            }

            int main(int argc, char* argv[])
            {
                HANDLE hThrd;
                DWORD thrdId;
                
            int n = 5;

                hThrd 
            = CreateThread(    NULL,
                                        
            0,
                                        thread_func,
                                        (LPVOID)
            &n,
                                        
            0,
                                        
            &thrdId);
                Sleep(
            2000);

                std::cout 
            << "main() done." << std::endl;

                
            return 0;
            }
            posted on 2010-06-05 20:16 lf426 閱讀(2645) 評論(2)  編輯 收藏 引用 所屬分類: 語言基礎、數據結構與算法Win32與VC

            FeedBack:
            # re: 在多線程中拋出的異常出錯? 2014-05-05 22:43 hak1985
            其實我就很希望能有這個功能,可以來實現對一個代碼段的超時控制;java里是可以這么做的。  回復  更多評論
              
            # re: 在多線程中拋出的異常出錯? 2014-05-05 22:44 hak1985
            其實這個功能很有用,可以實現對一個代碼段的超時控制,可惜c++不支持;java好像可以這么做  回復  更多評論
              
            99久久国产综合精品女同图片| 99久久精品国内| 亚洲国产成人精品女人久久久 | 中文字幕精品无码久久久久久3D日动漫 | 精品无码久久久久久久久久| 久久久国产一区二区三区| 狠狠色丁香久久婷婷综合蜜芽五月 | 成人亚洲欧美久久久久| 四虎影视久久久免费观看| 久久久噜噜噜久久中文福利| 国产福利电影一区二区三区久久久久成人精品综合 | 国内精品人妻无码久久久影院导航| 久久精品国产色蜜蜜麻豆| 久久久精品人妻一区二区三区蜜桃| 久久精品国产半推半就| 女人高潮久久久叫人喷水| 69久久精品无码一区二区| 7777精品伊人久久久大香线蕉| 久久99精品久久久久久| 大香伊人久久精品一区二区| 99久久亚洲综合精品网站| 国内高清久久久久久| 久久久人妻精品无码一区| 免费国产99久久久香蕉| 亚洲精品无码久久久久久| 日本精品久久久久久久久免费| 69SEX久久精品国产麻豆| 伊人久久精品无码av一区| 色综合久久中文字幕综合网| 国产真实乱对白精彩久久| 久久精品国产久精国产| 精品少妇人妻av无码久久| 天天爽天天狠久久久综合麻豆| 思思久久99热只有频精品66| 欧美一区二区久久精品| 日日狠狠久久偷偷色综合0| 久久久久久久综合综合狠狠| 7国产欧美日韩综合天堂中文久久久久| 无码AV波多野结衣久久| 三上悠亚久久精品| 国产精品99久久久久久人|