• <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>

            子彈 の VISIONS

            NEVER back down ~~

            C++博客 首頁(yè) 新隨筆 聯(lián)系 聚合 管理
              112 Posts :: 34 Stories :: 99 Comments :: 0 Trackbacks

            ??????? 通常,在寫(xiě)WINDOWS程序的時(shí)候我們會(huì)用 GetLastError()來(lái)獲得錯(cuò)誤代號(hào),進(jìn)而想要知道具體出錯(cuò)原因(文本描述),我們可以用 FormatMessage 函數(shù)來(lái)得到。
              下面示例一段代碼。

            ?1
            ?2 /*
            ?3 利用FormatMessage函數(shù)得到錯(cuò)誤代碼的文本顯示。而錯(cuò)誤代號(hào)則可由GetLastError()獲得。(_WINDOWS)
            ?4 */

            ?5
            ?6 ????DWORD nErrorNo =?GetLastError ( ); // 得到錯(cuò)誤代碼
            ?7 ????LPSTR?lpBuffer;????
            ?8 ????FormatMessage (?FORMAT_MESSAGE_ALLOCATE_BUFFER? |
            ?9 ???????? FORMAT_MESSAGE_IGNORE_INSERTS? |
            10 ????????FORMAT_MESSAGE_FROM_SYSTEM,
            11 ????????NULL,
            12 ????????nErrorNo, // 此乃錯(cuò)誤代碼,通常在程序中可由 GetLastError()得之
            13 ????????LANG_NEUTRAL,
            14 ????????(LPTSTR) & lpBuffer,
            15 ???????? 0 ,
            16 ????????NULL?);
            17 ????CString strErrorCause? = ?lpBuffer? ? ?_T(lpBuffer)?:?_T( " Sorry,?cannot?find?this?error?info. " );
            18 ????UpdateData (FALSE);
            19
            20 ???? // ?Free?the?buffer.
            21 ????LocalFree (lpBuffer);

            我這里編譯了一個(gè)簡(jiǎn)單的可執(zhí)行程序供給有需要的朋友 [ 下載?]。
            MD5: 50b4fd62cf3082a9a3131e0ca3a00a86? ErrorLookup.rar
            截圖:
            posted on 2006-05-24 16:18 子彈のVISIONS 閱讀(15285) 評(píng)論(4)  編輯 收藏 引用

            Feedback

            # 《Win32多線程程序設(shè)計(jì)》上的一個(gè)應(yīng)用 2006-05-31 12:50 子彈
            
            
            /*
            * MtVerify.h
            *
            * Error handling for applications in
            * "Multitheading Applications in Win32"
            *
            * The function PrintError() is marked as __inline so that it can be
            * included from one or more C or C++ files without multiple definition
            * errors. For the examples in this book, this works fine.
            * To use the PrintError() in an application, it should be taken out,
            * placed in its own source file, and the "__inline" declaration removed
            * so the function will be globally available.
            */

            #pragma comment( lib, "USER32" )

            #include
            #define MTASSERT(a) _ASSERTE(a)


            #define MTVERIFY(a) if (!(a)) PrintError(#a,__FILE__, __LINE__, GetLastError())

            __inline void PrintError(LPSTR linedesc, LPSTR filename, int lineno, DWORD errnum)
            {
            LPSTR lpBuffer;
            char errbuf[256];
            #ifdef _WINDOWS
            char modulename[MAX_PATH];
            #else // _WINDOWS
            DWORD numread;
            #endif // _WINDOWS

            FormatMessage( FORMAT_MESSAGE_ALLOCATE_BUFFER
            | FORMAT_MESSAGE_FROM_SYSTEM,
            NULL,
            errnum,
            LANG_NEUTRAL,
            (LPTSTR)&lpBuffer,
            0,
            NULL );

            wsprintf(errbuf, "\nThe following call failed at line %d in %s:\n\n"
            " %s\n\nReason: %s\n", lineno, filename, linedesc, lpBuffer);
            #ifndef _WINDOWS
            WriteFile(GetStdHandle(STD_ERROR_HANDLE), errbuf, strlen(errbuf), &numread, FALSE );
            Sleep(3000);
            #else
            GetModuleFileName(NULL, modulename, MAX_PATH);
            MessageBox(NULL, errbuf, modulename, MB_ICONWARNING|MB_OK|MB_TASKMODAL|MB_SETFOREGROUND);
            #endif
            exit(EXIT_FAILURE);
            }

            說(shuō)明:其中輸出到stderr和MessageBox部分可以把錯(cuò)誤信息Log到文件或者其他存儲(chǔ)中,以備分析錯(cuò)誤記錄。

            MTVERIFY宏的使用前提是:產(chǎn)生的錯(cuò)誤可以由GetLastError()捕捉。
              回復(fù)  更多評(píng)論
              

            # re: GetLastError與FormatMessage聯(lián)用得到出錯(cuò)原因 2008-02-28 18:15 匿名
            3Q  回復(fù)  更多評(píng)論
              

            # re: GetLastError與FormatMessage聯(lián)用得到出錯(cuò)原因 2009-05-02 14:34 calm
            lpBuffer:是一個(gè)指針
            但在使用時(shí) 用( LPTSTR )&buffer,不就是變成指針的地址,也就是指針的指針了 這是什么原因?   回復(fù)  更多評(píng)論
              

            # re: GetLastError與FormatMessage聯(lián)用得到出錯(cuò)原因 2009-07-04 11:26 路過(guò)
            @calm
            因?yàn)檫@個(gè)API是傳值,所以需要把指針的地址傳過(guò)去,這樣這個(gè)指針才能被API內(nèi)部修改,指向他申請(qǐng)的內(nèi)存空間。
              回復(fù)  更多評(píng)論
              


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            97久久天天综合色天天综合色hd| 亚洲精品无码久久久久AV麻豆| 久久久久女教师免费一区| 久久精品国产网红主播| 91精品国产乱码久久久久久 | 亚洲中文字幕无码一久久区| 亚洲综合日韩久久成人AV| 99久久99这里只有免费的精品| 精品免费久久久久国产一区 | 亚洲人成无码www久久久| 亚洲午夜久久久久久久久久| 久久综合九色综合久99| 久久中文字幕人妻熟av女| 国产精品久久久久久福利漫画| 久久婷婷五月综合成人D啪| 久久久青草久久久青草| 久久久久久久久久久| 99久久精品免费看国产一区二区三区 | 久久久久这里只有精品 | 伊人久久大香线蕉影院95| 超级97碰碰碰碰久久久久最新| 99久久99久久精品国产片果冻| 狠狠色综合网站久久久久久久高清| 国产精品久久久久aaaa| 久久国产免费直播| 久久久高清免费视频| 久久久精品久久久久久| 狠狠久久综合伊人不卡| 99re久久精品国产首页2020| 久久精品aⅴ无码中文字字幕重口| 久久久久久久女国产乱让韩| 亚洲欧美国产日韩综合久久| 久久久久国色AV免费看图片| 久久青草国产精品一区| 久久久久一区二区三区| 欧美久久综合性欧美| 久久99国产精品一区二区| 色综合久久最新中文字幕| 粉嫩小泬无遮挡久久久久久| 91精品国产9l久久久久| 精品久久久久久无码国产|