打印函数调用的堆栈信息

有些时候为了便于调试,我们需要记录函数调用的堆栈信息。为此,封装了一个类StackDumper,在相应的函数中调用该类的成员函数即可。

stack_dumper.h

#ifndef STACK_DUMPER_H
#define STACK_DUMPER_H

#ifdef _WIN32
#include <windows.h>  
#include <dbghelp.h>
#include <string>
#include <sstream>
#pragma comment (lib, "dbghelp.lib")  
#endif  // _WIN32

class StackDumper {
   
 public:
    StackDumper();
    ~StackDumper();
    void Destory();
    std::string DumpStack();

 private:
#ifdef _WIN32
    UINT max_name_length_;              // Max length of symbols' name.
    CONTEXT context_;                   // Store register addresses.
    STACKFRAME64 stackframe_;           // Call stack.
    HANDLE process_, thread_;           // Handle to current process & thread.
    PSYMBOL_INFO symbol_;               // Debugging symbol's information.
    IMAGEHLP_LINE6
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是在Android9的system/core/init/init.cpp文件HandleControlMessage函数打印函数调用堆栈信息的实现代码: ```c++ void HandleControlMessage(const std::vector<Subcontext>& subcontexts, const std::string& msg) { std::string cmd = android::base::Trim(msg); if (cmd.empty()) { return; } ALOGV("control message '%s'", cmd.c_str()); // 打印函数调用堆栈信息 android::base::ScopedLogSeverity severity(android::base::DEBUG); android::base::CallStack stack; ALOGD("Function call stack:\n%s", stack.ToString().c_str()); if (cmd == "restart") { // 重启系统 RestartProcess(); } else if (cmd == "reboot") { // 重启设备 DoReboot(); } else if (cmd == "shutdown") { // 关闭设备 DoShutdown(); } else if (StartsWith(cmd, "sigstop")) { // 发送SIGSTOP信号给指定进程 HandleSignalCommand(subcontexts, cmd, SIGSTOP); } else if (StartsWith(cmd, "sigcont")) { // 发送SIGCONT信号给指定进程 HandleSignalCommand(subcontexts, cmd, SIGCONT); } else if (StartsWith(cmd, "signal ")) { // 发送指定信号给指定进程 HandleSignalCommand(subcontexts, cmd.substr(strlen("signal ")), 0); } } ``` 其打印函数调用堆栈信息的代码为: ```c++ // 打印函数调用堆栈信息 android::base::ScopedLogSeverity severity(android::base::DEBUG); android::base::CallStack stack; ALOGD("Function call stack:\n%s", stack.ToString().c_str()); ``` 这段代码使用了Android库的android::base::CallStack类,用于获取当前函数调用堆栈信息,并使用Android库的android::base::Log类打印调用堆栈信息

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值