zoukankan      html  css  js  c++  java
  • 封装了一个C++类,当程序意外崩溃的时候可以生成dump文件,以便确定错误原因。

    #pragma once
    
    #include <windows.h>
    #include <dbghelp.h>
    
    #pragma comment(lib, "dbghelp.lib") 
    
    typedef void(__stdcall *PF_CallBack)(const char* msg);
    
    
    class MiniDump 
    {
    private:
        static      PF_CallBack     m_pFun;
        static      char            m_szProcessName[32];
    
    public:
        MiniDump(){};
        ~MiniDump(){};
    
        static void TcharToChar(TCHAR * tchar, char * _char);
        static void CharToTchar(const char * _char, TCHAR * tchar);
        static const char * GenerateDumpFilePath();
    
        static void EnableAutoMinDump(const char* pProcessName, PF_CallBack pFunc, bool bEnable = true);
        static LONG ApplicationUnhandledExceptionFilter(EXCEPTION_POINTERS *pException);
        static void CreateDumpFile(LPCWSTR lpstrDumpFilePathName, EXCEPTION_POINTERS *pException);
    
    };
    
    PF_CallBack MiniDump::m_pFun = NULL;
    char        MiniDump::m_szProcessName[32] = "test";
    
    void MiniDump::EnableAutoMinDump(const char* pProcessName, PF_CallBack pFunc, bool bEnable)
    {
        if (bEnable) {
            m_pFun = pFunc;
            memset(m_szProcessName, 0, sizeof(m_szProcessName));
            memcpy(m_szProcessName, pProcessName, strlen(pProcessName) + 1);
            SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)ApplicationUnhandledExceptionFilter);
        }
    }
    
    LONG MiniDump::ApplicationUnhandledExceptionFilter(EXCEPTION_POINTERS *pException)
    {
        TCHAR szDumpFile[MAX_PATH] = { 0 };
        CharToTchar(GenerateDumpFilePath(), szDumpFile);
        CreateDumpFile(szDumpFile, pException);
    
        if (m_pFun != NULL) {
            char szMsg[2048] = { 0 };
            m_pFun(szMsg);
        }
    
        return EXCEPTION_EXECUTE_HANDLER;
    }
    
    void MiniDump::CreateDumpFile(LPCWSTR lpstrDumpFilePathName, EXCEPTION_POINTERS *pException)
    {
        // 创建Dump文件;
        HANDLE hDumpFile = CreateFile(lpstrDumpFilePathName, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
        // Dump信息;
        if (hDumpFile != NULL && hDumpFile != INVALID_HANDLE_VALUE) {
            MINIDUMP_EXCEPTION_INFORMATION dumpInfo;
            dumpInfo.ExceptionPointers = pException;
            dumpInfo.ThreadId = GetCurrentThreadId();
            dumpInfo.ClientPointers = TRUE;
    
            // 写入Dump文件内容;
            MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hDumpFile, MiniDumpNormal, &dumpInfo, NULL, NULL);
            CloseHandle(hDumpFile);
        }
    }
    
    void MiniDump::TcharToChar(TCHAR * tchar, char * _char)
    {
        int iLength = 0;
        iLength = WideCharToMultiByte(CP_ACP, 0, tchar, -1, NULL, 0, NULL, NULL);
        WideCharToMultiByte(CP_ACP, 0, tchar, -1, _char, iLength, NULL, NULL);
    }
    
    void MiniDump::CharToTchar(const char * _char, TCHAR * tchar)
    {
        int iLength;
        iLength = MultiByteToWideChar(CP_ACP, 0, _char, strlen(_char) + 1, NULL, 0);
        MultiByteToWideChar(CP_ACP, 0, _char, strlen(_char) + 1, tchar, iLength);
    }
    
    const char * MiniDump::GenerateDumpFilePath()
    {
        //路径
        TCHAR szDumpDirT[MAX_PATH] = { 0 };
        GetCurrentDirectory(MAX_PATH, szDumpDirT);
        char szDumpDir[MAX_PATH] = { 0 };
        TcharToChar(szDumpDirT, szDumpDir);
    
        //时间
        SYSTEMTIME stTime;
        GetLocalTime(&stTime);
        char szCurtTime[64] = { 0 };
        sprintf_s(szCurtTime, sizeof(szCurtTime) / sizeof(char), "%04d-%02d-%02d-%02d-%02d-%02d", stTime.wYear, stTime.wMonth, stTime.wDay, stTime.wHour, stTime.wMinute, stTime.wSecond);
    
        //dump文件路径
        char szDumpFile[MAX_PATH] = { 0 };
        sprintf_s(szDumpFile, sizeof(szDumpFile) / sizeof(char), "%s\%s_%s.dmp", szDumpDir, m_szProcessName, szCurtTime);
    
        return szDumpFile;
    }
    

      

    #pragma once
    #include <windows.h>#include <dbghelp.h>
    #pragma comment(lib, "dbghelp.lib") 
    typedef void(__stdcall *PF_CallBack)(const char* msg);

    class MiniDump {private:    static      PF_CallBack     m_pFun;    static      char            m_szProcessName[32];
    public:    MiniDump(){};    ~MiniDump(){};
        static void TcharToChar(TCHAR * tchar, char * _char);    static void CharToTchar(const char * _char, TCHAR * tchar);    static const char * GenerateDumpFilePath();
        static void EnableAutoMinDump(const char* pProcessName, PF_CallBack pFunc, bool bEnable = true);    static LONG ApplicationUnhandledExceptionFilter(EXCEPTION_POINTERS *pException);    static void CreateDumpFile(LPCWSTR lpstrDumpFilePathName, EXCEPTION_POINTERS *pException);
    };
    PF_CallBack MiniDump::m_pFun = NULL;char        MiniDump::m_szProcessName[32] = "test";
    void MiniDump::EnableAutoMinDump(const char* pProcessName, PF_CallBack pFunc, bool bEnable){    if (bEnable) {        m_pFun = pFunc;        memset(m_szProcessName, 0, sizeof(m_szProcessName));        memcpy(m_szProcessName, pProcessName, strlen(pProcessName) + 1);        SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)ApplicationUnhandledExceptionFilter);    }}
    LONG MiniDump::ApplicationUnhandledExceptionFilter(EXCEPTION_POINTERS *pException){    TCHAR szDumpFile[MAX_PATH] = { 0 };    CharToTchar(GenerateDumpFilePath(), szDumpFile);    CreateDumpFile(szDumpFile, pException);
        if (m_pFun != NULL) {        char szMsg[2048] = { 0 };        m_pFun(szMsg);    }
        return EXCEPTION_EXECUTE_HANDLER;}
    void MiniDump::CreateDumpFile(LPCWSTR lpstrDumpFilePathName, EXCEPTION_POINTERS *pException){    // 创建Dump文件;    HANDLE hDumpFile = CreateFile(lpstrDumpFilePathName, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);    // Dump信息;    if (hDumpFile != NULL && hDumpFile != INVALID_HANDLE_VALUE) {        MINIDUMP_EXCEPTION_INFORMATION dumpInfo;        dumpInfo.ExceptionPointers = pException;        dumpInfo.ThreadId = GetCurrentThreadId();        dumpInfo.ClientPointers = TRUE;
            // 写入Dump文件内容;        MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hDumpFile, MiniDumpNormal, &dumpInfo, NULL, NULL);        CloseHandle(hDumpFile);    }}
    void MiniDump::TcharToChar(TCHAR * tchar, char * _char){    int iLength = 0;    iLength = WideCharToMultiByte(CP_ACP, 0, tchar, -1, NULL, 0, NULL, NULL);    WideCharToMultiByte(CP_ACP, 0, tchar, -1, _char, iLength, NULL, NULL);}
    void MiniDump::CharToTchar(const char * _char, TCHAR * tchar){    int iLength;    iLength = MultiByteToWideChar(CP_ACP, 0, _char, strlen(_char) + 1, NULL, 0);    MultiByteToWideChar(CP_ACP, 0, _char, strlen(_char) + 1, tchar, iLength);}
    const char * MiniDump::GenerateDumpFilePath(){    //路径    TCHAR szDumpDirT[MAX_PATH] = { 0 };    GetCurrentDirectory(MAX_PATH, szDumpDirT);    char szDumpDir[MAX_PATH] = { 0 };    TcharToChar(szDumpDirT, szDumpDir);
        //时间    SYSTEMTIME stTime;    GetLocalTime(&stTime);    char szCurtTime[64] = { 0 };    sprintf_s(szCurtTime, sizeof(szCurtTime) / sizeof(char), "%04d-%02d-%02d-%02d-%02d-%02d", stTime.wYear, stTime.wMonth, stTime.wDay, stTime.wHour, stTime.wMinute, stTime.wSecond);
        //dump文件路径    char szDumpFile[MAX_PATH] = { 0 };    sprintf_s(szDumpFile, sizeof(szDumpFile) / sizeof(char), "%s\%s_%s.dmp", szDumpDir, m_szProcessName, szCurtTime);
        return szDumpFile;}

  • 相关阅读:
    自定义瀑布流
    传值 属性 block 单例 协议
    sqlite数据库中 保存和读取UIData对象
    SQL
    关于在Xcode控制台打印的注意点
    synthesize的作用
    iPhone屏幕尺寸/launch尺寸/icon尺寸
    关于TableView上有一段留白的解决方法
    mac显示隐藏文件
    多线程之GCD
  • 原文地址:https://www.cnblogs.com/hailong88/p/13275373.html
Copyright © 2011-2022 走看看