我在不同的源文件中有两个函数:
a.cpp
void A()
{
B();
}
b.cpp
void B()
{
std::cout << "B() called from file: " << ??? << " line: " << ??? << std::endl;
}
如何获取通话的文件名和行号?
答案 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