• <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>
            隨筆-90  評論-947  文章-0  trackbacks-0

            近來遇上一個很詭異的 bug:InternetOpenURL 內部發生 crash。雖說發生問題的時刻總是處于這個 API 內部,可也一直不敢確定不是其他原因引起的,就這么一直拖著。

            前兩天終于有可以隨時操作的且重現幾率非常高的機器了,測試了一下,發現一個規律:只要在調用 InternetOpenURL 之前調用過 SHGetFolderPath,此問題的重現幾率就非常高;如果沒有調用過 SHGetFolderPath,則基本不出現。

            目前網上找到的一個幾乎唯一的帖子是 http://social.msdn.microsoft.com/forums/en-US/vcgeneral/thread/2982efc6-8403-4577-9dba-ad5cfdf01753,現象幾乎一模一樣。只可惜沒有有價值的回復。該文章的作者指出的 VPN 等網絡原因好像不是關鍵,在我這里是很普通的局域網,一樣能出現。

            測試代碼如下:

            #include <Windows.h>
            #include <tchar.h>
            #include <ShlObj.h>

            #include <WinInet.h>
            #pragma comment(lib, "wininet.lib")

            #define URL _T("http://www.baidu.com/")

            int main()
            {
                TCHAR szCommonAppData[MAX_PATH];
                SHGetFolderPath(NULL, CSIDL_COMMON_APPDATA, NULL, SHGFP_TYPE_CURRENT, szCommonAppData);

                HINTERNET hInternet = InternetOpen(_T("WCU"), INTERNET_OPEN_TYPE_PRECONFIG_WITH_NO_AUTOPROXY, NULL, NULL, 0);

                if (hInternet == NULL)
                {
                    return 0;
                }

                HINTERNET hInternetFile = InternetOpenUrl(hInternet, URL, NULL, 0, INTERNET_FLAG_NO_UI | INTERNET_FLAG_RELOAD, 0);

                if (hInternetFile == NULL)
                {
                    InternetCloseHandle(hInternet);
                    return 0;
                }

                InternetCloseHandle(hInternetFile);
                InternetCloseHandle(hInternet);

                return 0;
            }

            在能夠出現此問題的機器上,Ctrl + F5 直接運行,幾乎每次必現;如果 F5 調試運行,則幾率小一點,但是跑個七八次左右基本上能出現。目前 XP 32/64 上都有發現這個問題,Vista/Win7 上暫時沒有發生此現象。(如果 InternetOpenURL 換成 InternetConnect、HttpOpenRequest、HttpSendrequest,則會 crash 在 HttpSendRequest 內。)

            附件是一個測試工程,附帶上了 Debug、Release 版本的 EXE、PDB 文件以及 Crash 時的 Dump 文件。請有心人幫忙看看。^_^
            點擊下載

            可是,如果這個問題確實存在,為什么網上查到的相關內容這么少呢?奇怪~

            posted on 2010-08-26 11:19 溪流 閱讀(3231) 評論(7)  編輯 收藏 引用 所屬分類: Windows

            評論:
            # re: InternetOpenURL 內部 crash 的問題 2010-08-26 16:01 | nickx
            在 win2003(虛擬機) 中測試沒有 crash  回復  更多評論
              
            # re: InternetOpenURL 內部 crash 的問題 2010-08-26 16:03 | nickx
            可以抓一個 dump 文件試試。
            發到我的郵箱吧 nicoster at gmail com  回復  更多評論
              
            # re: InternetOpenURL 內部 crash 的問題 2010-08-26 17:17 | 溪流
            @nickx
            dump 附件里有,現在忙著,等等發給你。只有少數系統會出現,只是一旦出現了,重現的機會比較多的。  回復  更多評論
              
            # re: InternetOpenURL 內部 crash 的問題 2010-09-02 13:06 | cui_y_x
            SHGetFolderPath在shell32.dll中定義,shell32.dll又引入了wininet.dll,wininet.dll中使用了一些全局的互斥量,可能是由于某種原因wininet內部死鎖了。wininet的確被很多人所病垢,用起來有時是會有莫名其妙的問題,可以考慮使用新的winhttp來代替。  回復  更多評論
              
            # re: InternetOpenURL 內部 crash 的問題 2010-09-03 01:41 | 溪流
            @cui_y_x
            多謝指教哈,嘗試下WinHttp系列~  回復  更多評論
              
            # re: InternetOpenURL 內部 crash 的問題 2012-12-27 17:17 | aa
            我也出現這個問題了 搜到這里了 不知道樓主怎么解決的  回復  更多評論
              
            # re: InternetOpenURL 內部 crash 的問題 2012-12-29 15:42 | 溪流
            @aa
            當時是換用了 WinHttp  回復  更多評論
              
            国产亚洲精久久久久久无码AV| 亚洲国产成人久久精品99| 人人狠狠综合88综合久久| 国产一区二区精品久久| av无码久久久久久不卡网站 | 亚洲国产精品成人久久| 亚洲第一永久AV网站久久精品男人的天堂AV | 久久99精品免费一区二区| 91超碰碰碰碰久久久久久综合| 97久久精品午夜一区二区| 久久99国产精品一区二区| 色噜噜狠狠先锋影音久久| 精品久久久久久国产免费了| 久久99热这里只有精品国产 | 久久九九亚洲精品| 伊人久久综合热线大杳蕉下载| 久久香蕉国产线看观看99| 九九久久精品无码专区| 国产精品久久久久久五月尺| 久久福利资源国产精品999| 亚洲va久久久噜噜噜久久天堂| 久久久无码一区二区三区| 久久亚洲国产精品一区二区| 97精品国产97久久久久久免费 | 久久最近最新中文字幕大全| 国产精品99久久久久久猫咪| 一极黄色视频久久网站| 久久夜色精品国产欧美乱| 97久久精品人人做人人爽| 伊人色综合九久久天天蜜桃| 中文字幕久久久久人妻| 国产福利电影一区二区三区久久久久成人精品综合 | 久久精品国产精品亚洲下载| 久久亚洲高清综合| 91精品国产高清久久久久久io| 99久久这里只有精品| 日韩精品久久久久久| 伊人久久综合精品无码AV专区| 国产美女久久久| 久久精品国产清自在天天线| 久久久久久免费一区二区三区|