我们可以实现一个 MACRO 来注册打印名称吗?如下所示:
1.C
O_PRINT_NAME_REGISTER(NET_TRACE)
O_PRINT_NAME_REGISTER(MAIN_TRACE)
void example(void)
{
NET_TRACE(" net log"); // LINE 20
MAIN_TRACE(" main log"); // LINE 21
}
预期输出
example - 20: net log
example - 21: main log
如何定义O_PRINT_NAME_REGISTER()
?
最佳答案
不可能从另一个宏定义一个宏。来自 C99 6.10.3.4/3“重新扫描和进一步替换”:
The resulting completely macro-replaced preprocessing token sequence is not processed as a preprocessing directive even if it resembles one,
可以使用宏准备一个函数,但是这样您将不会获得行号和函数名信息。
例如:
#define O_PRINT_NAME_REGISTER(FN_NAME) static void FN_NAME(char *arg) { \
printf("%s\n", arg); \
}
您可以改为定义一个宏,该宏将像 NET_TRACE
这样的宏作为参数,并将函数名称和行号信息传递给适当的函数,或者将适当的日志记录函数指针传递给可以处理函数的通用函数名称和行号信息。
关于我们可以将 MACRO 名称定义为特定字符串吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36685605/