• <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>
            春暖花開(kāi)
            雪化了,花開(kāi)了,春天來(lái)了
            posts - 149,comments - 125,trackbacks - 0

                  過(guò)年前,從china-pub買(mǎi)的。一直也沒(méi)有安下心來(lái)讀。看今年找工作的境況,也不得不抓把緊了。也愿與c++博客的各位朋友分享我的學(xué)習(xí)心得。
                   步入主題。

                     這一章開(kāi)篇介紹了windows函數(shù)的幾種返回值:VOID,BOOL,HANDLE,PVOID,LONG/DWORD。讓我們明白,僅僅通過(guò)返回值,我們是不能清楚函數(shù)調(diào)用為什么會(huì)失敗的。

                     windows內(nèi)部,函數(shù)檢測(cè)到錯(cuò)誤會(huì)采用什么機(jī)制呢?它是采用“線(xiàn)程本地存儲(chǔ)區(qū)”的機(jī)制來(lái)講相應(yīng)的錯(cuò)誤代碼與“主調(diào)線(xiàn)程”關(guān)聯(lián)到一起。它可以使不同的線(xiàn)程能獨(dú)立運(yùn)行,不會(huì)出現(xiàn)相互干擾對(duì)方的錯(cuò)誤代碼的情況。

                     函數(shù)返回的時(shí)候,其返回值會(huì)指出已發(fā)生的一個(gè)錯(cuò)誤。

                     我們查看具體是什么錯(cuò)誤,在相應(yīng)的函數(shù)執(zhí)行完成后調(diào)用GetLastError()即可。

                     windows中,錯(cuò)誤有三種表示:
                     一個(gè)消息ID(如ERROR_PATH_NOT_FOUND)
                        消息文本(如the system cannot find the path specified)
                     一個(gè)編號(hào)(盡量避免使用)

                     調(diào)試程序的時(shí)候,我們可以配置watch窗口,讓它始終顯示線(xiàn)程的上一個(gè)錯(cuò)誤代碼和錯(cuò)誤的文本描述。如$err,hr。hr是要顯示錯(cuò)誤代碼的消息文本。不過(guò)我在windows mobile的環(huán)境下沒(méi)有成功,沒(méi)有弄清楚為什么。

                     那么我們?cè)趺丛谧约旱某绦蛑酗@示消息文本呢?文章介紹了利用FormatMessage函數(shù)。這里我也介紹一下這個(gè)函數(shù)的用法:
                     (下面的介紹摘自:http://www.shnenglu.com/bidepan2023/archive/2008/02/03/42433.html
                     DWORD FormatMessage(
                         DWORD dwFlags,
                         LPCVOID lpSource,
                         DWORD dwMessageId,
                         DWORD dwLanguageId,
                         LPTSTR lpBuffer,
                         DWORD nSize,
                         va_list* Arguments
                         );

                     dwFlags:
                     # FORMAT_MESSAGE_ALLOCATE_BUFFER // 此函數(shù)會(huì)分配內(nèi)存以包含描述字串。
                     # FORMAT_MESSAGE_FROM_SYSTEM,  // 在系統(tǒng)的id映射表中尋找描述字串
                     # FORMAT_MESSAGE_FROM_HMODULE  // 在其他資源模塊中尋找描述字串
                     # FORMAT_MESSAGE_FROM_STRING   // 消息ID是個(gè)字串,不是個(gè)DWORD
                     #FORMAT_MESSAGE_IGNORE_INSERTS // 允許我們獲得含有%占位符的消息,不傳遞這個(gè)標(biāo)志,就必須在Arguments參數(shù)中提供這些占位符的信息
                     通常為:FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM

                     lpSource:
                     # 指定了FORMAT_MESSAGE_FROM_HMODULE的話(huà),此參數(shù)表示模塊的HANDLE
                     # 指定了FORMAT_MESSAGE_FROM_STRING的話(huà),此參數(shù)表示id字串
                     通常為:NULL

                     dwMessageId:
                     消息ID;如果指定FORMAT_MESSAGE_FROM_STRING,將被忽略。

                     dwLanguageId:
                     消息描述所用的語(yǔ)言
                     通常為:0表示自動(dòng)選擇

                     lpBuffer:
                     #如果未指定FORMAT_MESSAGE_ALLOCATE_BUFFER,則為自己提供的緩沖區(qū)
                     #否則為系統(tǒng)LocalAlloc分配,需要被用戶(hù)LocalFree

                     nSize:
                     #如果未指定FORMAT_MESSAGE_ALLOCATE_BUFFER,則為自己提供的緩沖區(qū)大小
                     #否則為系統(tǒng)LocalAlloc分配之最小緩沖區(qū)大小

                     Arguments:
                     通常不使用


            例子:

            void ShowError()
            {
                DWORD dwError 
            = GetLastError();

                HLOCAL hlocal 
            = NULL;

                
            // Use the default system locale since we look for Windows messages.
                
            // Note: this MAKELANGID combination has 0 as value
                DWORD systemLocale = MAKELANGID(LANG_NEUTRAL, SUBLANG_NEUTRAL);

                BOOL fOk 
            = FormatMessage(
                    FORMAT_MESSAGE_FROM_SYSTEM 
            | FORMAT_MESSAGE_IGNORE_INSERTS |
                    FORMAT_MESSAGE_ALLOCATE_BUFFER, 
                    NULL, dwError, systemLocale, 
                    (PTSTR) 
            &hlocal, 0, NULL);

                
            if (!fOk) {
                    
            // Is it a network-related error?
                    HMODULE hDll = LoadLibraryEx(TEXT("netmsg.dll"), NULL, 
                        DONT_RESOLVE_DLL_REFERENCES);

                    
            if (hDll != NULL) {
                        fOk 
            = FormatMessage(
                            FORMAT_MESSAGE_FROM_HMODULE 
            | FORMAT_MESSAGE_IGNORE_INSERTS |
                            FORMAT_MESSAGE_ALLOCATE_BUFFER,
                            hDll, dwError, systemLocale,
                            (PTSTR) 
            &hlocal, 0, NULL);
                        FreeLibrary(hDll);
                    }

                }


                
            if (fOk && (hlocal != NULL))
                
            {
                    OutputDebugString((PCTSTR) LocalLock(hlocal));
                    LocalFree(hlocal);
                }

            }



                  這個(gè)是書(shū)中的例子的代碼,我只是將它歸結(jié)為了一個(gè)函數(shù)ErrorShow。這樣我們?cè)谝粋€(gè)函數(shù)的后面調(diào)用,直接可以知道錯(cuò)誤的原因。不過(guò)環(huán)境我是在smart device 的DEBUG環(huán)境下調(diào)時(shí)的,OutputDebugString會(huì)輸出相應(yīng)的字符串。

                  這個(gè)例子中同時(shí)展示了FormatMessage的兩種用法。觀察一下第二個(gè)參數(shù)就明白了。

                  visual studio 也提供了一個(gè)查詢(xún)錯(cuò)誤的小工具,為Error Lookup。通過(guò)以上的示例,我們就知道其相應(yīng)的工作原理呢。

                  這本書(shū)的源碼的下載地址:http://wintellect.com/Books.aspx 
                  大家如果對(duì)windows 編程感興趣的話(huà),不妨下來(lái)看看。

            posted on 2009-02-20 00:24 Sandy 閱讀(2339) 評(píng)論(4)  編輯 收藏 引用 所屬分類(lèi): windows學(xué)習(xí)

            FeedBack:
            # re: Windows核心編程:第一章錯(cuò)誤處理學(xué)習(xí)筆記
            2009-02-23 16:25 | 深邃者
            不錯(cuò) 我也再看這本書(shū) 看到第七章了 可以一起討論 呵呵  回復(fù)  更多評(píng)論
              
            # re: Windows核心編程:第一章錯(cuò)誤處理學(xué)習(xí)筆記
            2009-02-24 09:30 | Sandy
            @深邃者
            呵呵,好.一起研究
              回復(fù)  更多評(píng)論
              
            # re: Windows核心編程:第一章錯(cuò)誤處理學(xué)習(xí)筆記
            2009-03-11 19:46 | 鳳凰羽翼
            您好,我也是看了核心編程,有個(gè)小問(wèn)題,就是輸出的時(shí)候?yàn)槭裁匆胠ocalLock呢,我不用的話(huà)也可以輸出啊。
            另:你也畢業(yè)生?  回復(fù)  更多評(píng)論
              
            # re: Windows核心編程:第一章錯(cuò)誤處理學(xué)習(xí)筆記
            2009-03-12 10:19 | Sandy
            @鳳凰羽翼
            這個(gè)我也是看例子這么寫(xiě)的。你這么一說(shuō),我還專(zhuān)門(mén)查了一下。
            http://www.cic.tsinghua.edu.cn/jdx/book4/dlz.htm
            中提到加鎖與解鎖,它是這樣說(shuō)的 :
            “不管是可移動(dòng)對(duì)象還是可刪除對(duì)象,在它分配后其內(nèi)存句柄是不變的,它是內(nèi)存對(duì)象的恒定引用。但是,應(yīng)用程序無(wú)法通過(guò)內(nèi)存句柄直接存取內(nèi)存對(duì)象,應(yīng)用程序要存取內(nèi)存對(duì)象還必須獲得它的近地址,這通過(guò)調(diào)用LocalLock函數(shù)實(shí)現(xiàn)。LocalLock函數(shù)將局部?jī)?nèi)存對(duì)象暫時(shí)固定在局部堆的某一位置,并返回該地址的近地址值,此地址可供應(yīng)用程序存取內(nèi)存對(duì)象使用,它在應(yīng)用程序調(diào)用 LocalUnlock函數(shù)解鎖此內(nèi)存對(duì)象之前有效。”

            它的例子如果這樣用的話(huà),那么在
            FormatMessage中調(diào)用系統(tǒng)LocalAlloc分配,需要對(duì)內(nèi)存對(duì)象進(jìn)行加鎖與解鎖。

            呵呵,這只是我的理解而已。

            另:你也畢業(yè)生?
            對(duì)啊,不過(guò)我明年才會(huì)畢業(yè)呢!  回復(fù)  更多評(píng)論
              
            夜夜亚洲天天久久| 国产成人精品综合久久久久| 国产亚洲欧美成人久久片| 国产91久久精品一区二区| 久久青青草原综合伊人| 久久久久国产精品麻豆AR影院 | 久久天堂AV综合合色蜜桃网| 99久久久国产精品免费无卡顿| 亚洲综合久久综合激情久久| 久久久久久亚洲精品影院| 97久久香蕉国产线看观看| 久久精品无码一区二区日韩AV| 久久夜色精品国产噜噜亚洲AV | 精品久久人妻av中文字幕| 久久人人爽人人爽人人AV| 久久强奷乱码老熟女网站| 久久99精品久久久久久久不卡| 久久天天躁狠狠躁夜夜2020老熟妇 | 人妻少妇精品久久| 狠狠狠色丁香婷婷综合久久俺| 久久久午夜精品福利内容| 久久久久国产一区二区| 久久综合九色综合久99| 2021少妇久久久久久久久久| 97久久国产露脸精品国产| 天天做夜夜做久久做狠狠| 国产精品99久久不卡| 色综合久久天天综合| 久久免费视频网站| 久久精品国产免费| 国产亚洲精品美女久久久| 久久精品www人人爽人人| 久久久亚洲欧洲日产国码二区| 久久精品国产清自在天天线| 奇米影视7777久久精品人人爽| 青草久久久国产线免观| 欧美性大战久久久久久| 久久亚洲国产精品123区| 亚洲国产精品综合久久一线| 久久最新免费视频| 精品国产乱码久久久久软件|