• <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年7月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            E-mail:zbln426@163.com QQ:85132383 長(zhǎng)期尋找對(duì)戰(zhàn)略游戲感興趣的合作伙伴。

            常用鏈接

            留言簿(21)

            隨筆分類

            隨筆檔案

            SDL相關(guān)網(wǎng)站

            我的個(gè)人網(wǎng)頁(yè)

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 493186
            • 排名 - 39

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            以下以win32平臺(tái)為例。我們先看一個(gè)非多線程的程序:
            #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;
            }
            可以看到,函數(shù)thread_func()可以正確的拋出異常并被main()的catch捕捉。但是,如果用一個(gè)新線程來(lái)運(yùn)行thread_func()會(huì)出現(xiàn)什么情況呢?
            #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;
            }
            很不幸,這個(gè)程序編譯的時(shí)候是可以通過(guò)的,但是運(yùn)行時(shí)出錯(cuò):
            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.
            請(qǐng)按任意鍵繼續(xù). . .
            而且同時(shí)會(huì)有一個(gè)運(yùn)行時(shí)錯(cuò)誤的提示。事實(shí)上,這個(gè)錯(cuò)誤提示意味著程序在沒(méi)有發(fā)現(xiàn)try{}的時(shí)候看到了throw。
            通過(guò)試驗(yàn),我發(fā)現(xiàn)系統(tǒng)(這里是win32)不能將CreateThread()所產(chǎn)生的線程歸結(jié)到try{}中。更加嚴(yán)重的情況是,即使用一個(gè)函數(shù)囊括了整個(gè)程序,然后try這個(gè)函數(shù),其他線程依然脫離了這個(gè)try。
            所以,一個(gè)解決方法是,凡是遇到新的線程,必須在新線程中重新寫異常處理。不然,就如google代碼標(biāo)準(zhǔn)里所說(shuō)的那樣,不使用C++的異常機(jī)制。畢竟C++沒(méi)有定義多線程的標(biāo)準(zhǔn),所以也就無(wú)從說(shuō)起多線程中異常處理的標(biāo)準(zhǔn)。
            最后附上在新線程寫異常處理的參考:
            #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;
            }

            FeedBack:
            # re: 在多線程中拋出的異常出錯(cuò)? 2014-05-05 22:43 hak1985
            其實(shí)我就很希望能有這個(gè)功能,可以來(lái)實(shí)現(xiàn)對(duì)一個(gè)代碼段的超時(shí)控制;java里是可以這么做的。  回復(fù)  更多評(píng)論
              
            # re: 在多線程中拋出的異常出錯(cuò)? 2014-05-05 22:44 hak1985
            其實(shí)這個(gè)功能很有用,可以實(shí)現(xiàn)對(duì)一個(gè)代碼段的超時(shí)控制,可惜c++不支持;java好像可以這么做  回復(fù)  更多評(píng)論
              
            国内精品久久人妻互换| 99久久精品国产一区二区蜜芽| 久久精品国产99国产电影网| 亚洲AV无码久久| 国产精品99久久久精品无码| 欧美成人免费观看久久| 免费精品久久久久久中文字幕| 久久夜色精品国产亚洲av| 久久久久亚洲av毛片大 | 久久精品99无色码中文字幕| 97精品伊人久久久大香线蕉| 成人精品一区二区久久久| 国产叼嘿久久精品久久| 久久天天日天天操综合伊人av| 人妻丰满?V无码久久不卡| 亚州日韩精品专区久久久| 久久午夜无码鲁丝片午夜精品| 久久影视国产亚洲| 亚洲国产精品无码久久| 国产精品久久久久久久久| 国内精品久久久久久久coent| 日本久久中文字幕| 久久国产高潮流白浆免费观看| 大伊人青草狠狠久久| 久久99精品久久久久久9蜜桃 | 久久夜色精品国产亚洲av| 欧美日韩精品久久久久| 东京热TOKYO综合久久精品| 国产精品va久久久久久久| 漂亮人妻被中出中文字幕久久| 久久99精品国产一区二区三区| 国产99久久久国产精免费| 伊人久久一区二区三区无码| 国产午夜精品久久久久免费视| 狠狠色综合网站久久久久久久| 精品人妻伦九区久久AAA片69 | 久久伊人精品青青草原高清| 久久久久九九精品影院| 久久九九精品99国产精品| 亚洲国产高清精品线久久 | 欧美亚洲另类久久综合|