如何在C ++中调用函数时打印每个函数名称?

时间:2014-01-18 19:47:20

标签: c++ function debugging

我正在探索一个庞大的代码库,我不是gdb的粉丝。我想添加一个 代码库中每个函数的第一行中的LOG(INFO) << __PRETTY_FUNCTION__。但那非常乏味。有没有人知道要进行所有函数调用以打印带有函数名称的LOG消息?

2 个答案:

答案 0 :(得分:2)

我做了类似的事情:

#include <iostream>

class LogScope
{
    public:
    LogScope(const char* scope, const char* file, int line = 0)
    :   m_scope(scope), m_file(file), m_line(line)
    {
        std::clog << "[Begin] " << m_scope << ", " << m_file << ", " << m_line << std::endl;
    }

    ~LogScope() {
        std::clog << "[End]   "  << m_scope << ", " << m_file << ", " << m_line << std::endl;
    }

    private:
    const char* m_scope;
    const char* m_file;
    int m_line;
};

#define NAME_AT_LINE_2(Name, Line) Name##_##Line
#define NAME_AT_LINE_1(Name, Line) NAME_AT_LINE_2(Name, Line)
#define NAME_AT_LINE(Name) NAME_AT_LINE_1(Name, __LINE__)

#define LOG_SCOPE \
    ::LogScope NAME_AT_LINE(log_scope)(__FUNCTION__, __FILE__, __LINE__)

void f() {
    LOG_SCOPE;
}

int main() {
    LOG_SCOPE;
    f();
}

答案 1 :(得分:0)

似乎是Automatically adding Enter/Exit Function Logs to a Project

的副本

但是,您可以考虑使用能够生成运行时调用树的gprof。您可以使用点图,这可能更容易阅读。