如何获取函数调用的文件名和行号?

时间:2014-01-09 14:05:55

标签: c++

我在不同的源文件中有两个函数:

a.cpp

void A()
{
    B();
}

b.cpp

void B()
{
    std::cout << "B() called from file: " << ??? << " line: " << ??? << std::endl;
}

如何获取通话的文件名和行号?

2 个答案:

答案 0 :(得分:9)

一般情况下,您可以通过将您的函数隐藏在宏调用后自动执行此操作,该调用通过__FILE____LINE__

void _B(const char* file, int line) { ... } 
#define B() _B(__FILE__, __LINE__)

但这绝不是一个万无一失的解决方案。开发人员可以直接调用_B或从生成的代码,汇编等调用_B ....其中可能没有有意义的文件/行号

OP询问了一个带参数的例子

void _C(int p1, char p2, const char* file, int line) { ... } 
#define C(p1, p2) _C(p1, p2, __FILE__, __LINE__)

答案 1 :(得分:1)

代码: printf("%s(%d)--:",__FILE__,__LINE__);

参考: http://gcc.gnu.org/onlinedocs/cpp/Standard-Predefined-Macros.html