52221863

Qt程式異常崩潰處理技巧(Win) - baidu_33570760的博客 - CSDN博客
關閉
(function () { var s = “_” + Math.random().toString(36).slice(2); document.write(‘
‘); (window.slotbydup = window.slotbydup || []).push({ id: ‘4740870’, container: s, size: ‘300,250’, display: ‘inlay-fix’ }); })();
document.getElementById("popuLayer_js_q").onload = function () { var styObjd = styObj = { width: "300px", "height": parseInt(250) + 28 }; window.CSDN.Layer.PopuLayer("#layerd", { storageName: "layerd", styleObj: styObjd, total: 50, expoire: 1000 * 60 });
var username = "baidu_33570760"; var _blogger = username; var blog_address = "http://blog.csdn.net/baidu_33570760"; var static_host = "http://static.blog.csdn.net"; var currentUserName = "";
    <div id="body">
        <div id="main">
            <div class="main">
                    <div class="ad_class">
                    </div>
window.quickReplyflag = true; var isBole = false; var fasrc="http://my.csdn.net/my/favorite/miniadd?t=Qt%e7%a8%8b%e5%bc%8f%e5%bc%82%e5%b8%b8%e5%b4%a9%e6%ba%83%e5%a4%84%e7%90%86%e6%8a%80%e5%b7%a7(Win)&u=http://blog.csdn.net/baidu_33570760/article/details/52221863"

Qt程式異常崩潰處理技巧(Win)

5772人閱讀 評論(0) 收藏 舉報
.embody{ padding:10px 10px 10px; margin:0 -20px; border-bottom:solid 1px #ededed; } .embody_b{ margin:0 ; padding:10px 0; } .embody .embody_t,.embody .embody_c{ display: inline-block; margin-right:10px; } .embody_t{ font-size: 12px; color:#999; } .embody_c{ font-size: 12px; } .embody_c img,.embody_c em{ display: inline-block; vertical-align: middle; } .embody_c img{ width:30px; height:30px; } .embody_c em{ margin: 0 20px 0 10px; color:#333; font-style: normal; } (function () {
            try
            {
                var lib = eval("("+
("#lib").attr("value")+")"); var html = ""; if (lib.err == 0) { $.each(lib.data, function (i) { var obj = lib.data[i]; //html += '' + obj.name + "  "; html += ' '; html += ' '; html += ' ' + obj.name + ''; html += ' '; }); if (html != "") { setTimeout(function () { ("#lib").html(html); ("#embody").show(); }, 100); } } } catch (err) { } });
分類:

     文章轉載來自     http://www.cnblogs.com/lcchuguo/p/5177715.html     作者 lcchuguo


這篇文章談的是 Qt4 程式在視窗系統下的異常崩潰處理技巧。所以須要在頭文件裏包括“#include <Windows.h>”。

首先,程式難免會有異常崩潰的時候。重要的是在崩潰時能及時把重要的數據保存好,將損失減少。

SetUnhandledExceptionFilter函數是Win32API的異常捕獲函數,在程式異常結束前。會調用該函數註冊的回調函數,這樣就能在進程終止前運行指定的代碼,達到比如保存數據的功能。

LONG ApplicationCrashHandler(EXCEPTION_POINTERS *pException){//程式異常捕獲
    /*
      ***保存數據代碼***
    */
    //這裏彈出一個錯誤對話框並退出程序
    EXCEPTION_RECORD* record = pException->ExceptionRecord;
    QString errCode(QString::number(record->ExceptionCode,16)),errAdr(QString::number((uint)record->ExceptionAddress,16)),errMod;
    QMessageBox::critical(NULL,"程式崩潰","<FONT size=4><div><b>對於發生的錯誤,表示誠摯的歉意</b><br/></div>"+
        QString("<div>錯誤代碼:%1</div><div>錯誤地址:%2</div></FONT>").arg(errCode).arg(errAdr),
        QMessageBox::Ok);
    return EXCEPTION_EXECUTE_HANDLER;
}

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    QTextCodec::setCodecForTr(QTextCodec::codecForLocale());
    QTextCodec::setCodecForCStrings(QTextCodec::codecForLocale());
    QTextCodec::setCodecForLocale(QTextCodec::codecForLocale());
    SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)ApplicationCrashHandler);//註冊異常捕獲函數
    MainWindow w;
    w.showMaximized();
    return a.exec();
}

保存數據僅是拯救措施,更重要的是找到錯誤的根源。若能在崩潰的同一時候,程式自己主動記錄下崩潰時的執行信息,將有助於修正工作。微軟提供了“DbgHelp”錯誤調試技術。調用相關功能就可以保存程式崩潰時的信息,然後藉助WinDbg軟件就能分析出當時的執行狀況。

調用“DbgHelp”的MiniDumpWriteDump函數保存以“.dmp”爲後綴的Dump文件,該文件能被WinDbg讀取並分析。

你須要加入頭文件“#include <DbgHelp.h>”,在Pro文件里加入“LIBS += -lDbgHelp”。目的是鏈接DbgHelp庫。

LONG ApplicationCrashHandler(EXCEPTION_POINTERS *pException){//程式異常捕獲
    /*
      ***保存數據代碼***
    */
    //創建 Dump 文件
    HANDLE hDumpFile = CreateFile(QTime::currentTime().toString("HH時mm分ss秒zzz.dmp").utf16(), GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
    if( hDumpFile != INVALID_HANDLE_VALUE){
        //Dump信息
        MINIDUMP_EXCEPTION_INFORMATION dumpInfo;
        dumpInfo.ExceptionPointers = pException;
        dumpInfo.ThreadId = GetCurrentThreadId();
        dumpInfo.ClientPointers = TRUE;
        //寫入Dump文件內容
        MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hDumpFile, MiniDumpNormal, &dumpInfo, NULL, NULL);
    }
    //這裏彈出一個錯誤對話框並退出程序
    EXCEPTION_RECORD* record = pException->ExceptionRecord;
    QString errCode(QString::number(record->ExceptionCode,16)),errAdr(QString::number((uint)record->ExceptionAddress,16)),errMod;
    QMessageBox::critical(NULL,"程式崩潰","<FONT size=4><div><b>對於發生的錯誤,表示誠摯的歉意</b><br/></div>"+
        QString("<div>錯誤代碼:%1</div><div>錯誤地址:%2</div></FONT>").arg(errCode).arg(errAdr),
        QMessageBox::Ok);
    return EXCEPTION_EXECUTE_HANDLER;
}

當被錯誤困擾得焦頭爛額的時候。若是老天能直接告訴錯誤在哪一行代碼該有多好呀。其實WinDbg就能做到。

在項目的proproject文件裏增加:QMAKE_LFLAGS_RELEASE = /INCREMENTAL:NO /DEBUG

這句話的目的是Release版也將生成“.pdb”後綴的調試信息文件。在使用WinDbg導入Dump前。指定好源代碼與pdb文件的位置。就可以在錯誤報告內看到罪魁禍首是哪一行代碼。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章