欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

C++软件添加dump调试打印日志(推荐)

时间:2021-02-15 10:22:19|栏目:C代码|点击:

C++软件添加dump调试打印日志(推荐)

#include <DbgHelp.h>

#pragma comment(lib, "dbghelp.lib")

LONG WINAPI TopLevelExceptionFilter(struct _EXCEPTION_POINTERS *pExceptionInfo) 
{
    //cout << "Enter TopLevelExceptionFilter Function" << endl; 
   TCHAR szPath[MAX_PATH] = { 0 };
   TCHAR szFileName[MAX_PATH] = { 0 };
   TCHAR* szVersion = "v1.0";
   TCHAR dwBufferSize = MAX_PATH;
   SYSTEMTIME stLocalTime;
   GetLocalTime(&stLocalTime);
   CreateDirectory(szFileName, NULL);
   StringCchPrintf(szFileName, MAX_PATH, "%s-%04d%02d%02d-%02d%02d%02d-%ld-%ld.dmp",
   szVersion, stLocalTime.wYear, stLocalTime.wMonth, stLocalTime.wDay,
   stLocalTime.wHour, stLocalTime.wMinute, stLocalTime.wSecond,
   GetCurrentProcessId(), GetCurrentThreadId());

    HANDLE hFile = CreateFile(szFileName, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); 
   MINIDUMP_EXCEPTION_INFORMATION stExceptionParam; 
    stExceptionParam.ThreadId  = GetCurrentThreadId(); 
    stExceptionParam.ExceptionPointers = pExceptionInfo; 
    stExceptionParam.ClientPointers  = FALSE; 
    MiniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), hFile, MiniDumpWithFullMemory, &stExceptionParam, NULL, NULL); 
    CloseHandle(hFile); 
    getchar();

    return EXCEPTION_EXECUTE_HANDLER;
}

//----------------------------------------------

在程序最开始的地方调用这个函数

SetUnhandledExceptionFilter(TopLevelExceptionFilter);

上一篇:举例讲解C语言程序中对二叉树数据结构的各种遍历方式

栏    目:C代码

下一篇:C语言之实现控制台光标随意移动的实例代码

本文标题:C++软件添加dump调试打印日志(推荐)

本文地址:http://www.codeinn.net/misctech/63467.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有