如何从可变长度函数创建宏?其中宏值是另一个可变长度函数

how to create a macro from variable length function? where macro value is another variable length function

我正在尝试创建一个日志函数,它将打印文件名、函数名、行号和错误消息。

有没有办法为只接受日志类型的小函数创建宏,msg 和宏值将添加 FILE, func, LINE 并调用实际函数

可能是这样的:

#define func(int type,const char *msg, ...) \
        func(int type,char *__FILE__,char *__func__,char *__LINE__,const *msg,...)

如果你想创建一个在调用期间替换或添加一些参数的宏,你 不必将它写成原型,但是,因为 C 预处理器是一个简单的文本替换处理器,你可以把它写成调用本身。

所以你的宏定义变成:

#define func(type, msg, ...) \
        func(type, __FILE__, __func__, __LINE__, msg, __VA_ARGS__)

C 预处理器为符号 __VA_ARGS__ 分配从省略号 (...) 开始的参数序列,包括冒号。

现在使用宏,如下例所示:

func(MYTYPE, "Info function called with stack: '%s' size %ld", bIsPrivilegedStack(stack) ? "Privileged" : "User", StackSize);

将翻译成:

func(MYTYPE, __FILE__, __func__, __LINE__, "Infofunction called with stack: '%s' size %ld", bIsPrivilegedStack(stack) ? "Privileged" : "User", StackSize);

函数原型不在宏中,应该只写一次,最好包含在头文件中,并在任何调用之前出现在编译过程中。它将包含所有参数类型,如:

void func(int type, char *__FILE__, char *__func__, int _LINE__, const *msg, ...);

注意:预处理器符号__LINE__被定义为int,而不是char *

您的文件布局将或多或少:

//Prototype
void func(int type, char * file, char *fnc, int line, const *msg, ...);
//Macro definition
#define func(type, msg, ...) \
        func(type, __FILE__, __func__, __LINE__, msg, __VA_ARGS__)

//Usage
void foo(void)
{
    .....
    func(MYTYPE, "Info function called with stack: '%s' size %ld", bIsPrivilegedStack(stack) ? "Privileged" : "User", StackSize);
    .....
}