zoukankan      html  css  js  c++  java
  • c++ print stacktrace

    c++ stack print stack trace debug utility
    //z 2014-06-30 12:40:28 L.184'40772 BG57IV3@XCL T1809462551.K.F1586050276[T34,L813,R24,V564] is2120
    #include <DbgHelp.h>
    #pragma comment(lib, "dbghelp.lib")
    
    void printStack(void)
    {
    	char cBuff[1024] = {0};
    	unsigned int   i;
    	void         * stack[128];
    	unsigned short frames;
    	SYMBOL_INFO  * symbol;
    	HANDLE         process;
    
    	process = GetCurrentProcess();
    
    	SymInitialize(process, NULL, TRUE);
    
    	frames = CaptureStackBackTrace(0, 128, stack, NULL);
    	symbol = (SYMBOL_INFO *)calloc(sizeof(SYMBOL_INFO) + 256 * sizeof(char), 1);
    	symbol->MaxNameLen = 255;
    	symbol->SizeOfStruct = sizeof(SYMBOL_INFO);
    
    	OutputDebugString(_T("##########################################################################
    "));
    	for (i = 0; i < frames; i++)
    	{
    		SymFromAddr(process, (DWORD64)(stack[i]), 0, symbol);
    		sprintf_s(cBuff,1024,("%i: %s - 0x%0X
    "),frames - i - 1, symbol->Name, symbol->Address);
    		OutputDebugStringA(cBuff);
    	}
    	OutputDebugString(_T("--------------------------------------------------------------------
    "));
    
    	free(symbol);
    }
    //z is2120 2014-06-30 12:40:28 L.184'40772 BG57IV3@XCL T1809462551.K.F1586050276[T34,L813,R24,V564]



    @IS2120#CNBLOGS.T2169364049[T1,L65,R1,V259]:备忘
    $ € ₤ ₭ ₪ ₩ ₮ ₦ ₱ ฿ ₡ ₫ ﷼ ¥ ﷼ ₫ ₡ ฿ ₱ ₦ ₮ ₩ ₪ ₭ ₤ € $
  • 相关阅读:
    python-Lock进程同步解决互斥
    python-Event事件处理进程同步
    python-queue队列通信
    python-无名管道进程通信
    python-signal
    python-购物车
    python-多进程类封装
    python-哈夫曼树
    python-双向链表
    openstack 开发step-by-step
  • 原文地址:https://www.cnblogs.com/IS2120/p/6745649.html
Copyright © 2011-2022 走看看