我正在尝试创建一个C宏,给定一个类型名称会向其追加_info
,获取该地址并使用它调用一个函数。示例代码(不起作用):
#define new(X) __new(&(X_info))
struct classInfo
{
size_t size;
void* (*constructor)(void* p);
};
void* __new(struct classInfo* info, ...)
{
return info->constructor(malloc(info->size));
}
void* queue_constructor(void* p)
{
return p;
}
typedef struct
{
uint64_t data;
} queue_t;
const struct classInfo queue_t_info = { .size = sizeof(queue_t),
.constructor = &queue_constructor};
int main(int argc, char** argv)
{
queue_t* p = new(queue_t);
return 0;
}
预处理器似乎不想扩展X,因为它是关于未定义的符号X_info
的错误。不知道我应该在宏上修改什么来解决这个问题。
答案 0 :(得分:8)
您需要使用预处理器的标记连接功能;否则它认为X_info
本身就是一个标记:
#define new(X) __new(&(X ## _info))
预处理器不会扩展X
中的X_info
的原因是,如果实际上存在一个名为X_info
的标识符,则会产生很大问题宏。
作为旁注,还有字符串化功能:如果X
是例如Person
,"X"
将保持"X"
,而#X
将展开为字符串常量"Person"
。