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 += ' ("#lib").html(html);("#embody").show(); }, 100); } } } catch (err) { } });
分类:
作者同类文章 X

         文章转载来自     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文件的位置。就可以在错误报告内看到罪魁祸首是哪一行代码。


    • 0
      点赞
    • 0
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值