0

我有,我传递一个参数,并使用该定义基于输入名称的新变量宏:在宏变量中替换字符串?

#define DO_X(x) char _do_x_var_ ## x; /* other things */ 

问题是如果我通过在结构体变量,它打破:

DO_X(some_struct->thing) 

变为:

char _do_x_var_some_struct->thing; /* other things */ 

编辑:我想它,以评估什么是:

char _do_x_var_some_struct__thing; /* other things */ 

(或含有类似输入的东西任何有效的变量名)

我真正想要的是这些工作:

#define DO_X(x) for(char _do_x_var_ ## x; /*things*/) 
DO_X(x){ 
    DO_X(y) { 
     /*things*/ 
    } 
} 

DO_X(object->x){ 
    DO_X(object->y) { 
     /*things*/ 
    } 
} 

但对于这些失败:

#define DO_X(x) for(char _do_x_var_ ## x; /*things*/) 
DO_X(x){ 
    DO_X(x) { // <-- multiple definition of _do_x_var_x 
     /*things*/ 
    } 
} 

DO_X(object->x){ 
    DO_X(object->x) { // <-- multiple definition of _do_x_var_object__x (or whatever) 
     /*things*/ 
    } 
} 

有什么方法可以使这项工作?也许用__替代->什么的?我找到了连接方法,但不能替换字符串..

+0

你能澄清你想让宏给你什么吗? – 2010-10-27 22:17:24

+0

1.您是否试图在其外部声明一个类变量? 2.这是宏的死亡。 – 2010-10-27 22:20:46

+0

@奥利查尔斯沃斯:我补充说明我想要的东西 – 2010-10-27 22:32:22

回答

4

您还没有找到重写任意字符串的方法,因为宏不能这样做。宏名称必须是有效的标识符,其中->不是。 C预处理器的功能非常有限。你可以看看m4是否有更强大的预处理器,但你可能会走错路。

2

我不知道任何预处理器机制将struct-> element参数视为两个单独的标记或将 - >自动转换为下划线。我的建议是有一个单独的宏,例如DO_X2(struct_ptr,element),它会在需要时添加“ - >”或“_”。然后,您可以根据需要使用DO_X或DO_X2。

如果您打算按照指示使用这些宏,则存在单独的问题。内部for循环可以声明完全相同的变量名称,因为它们具有不同的范围,所以它不会被视为错误。例如,假设你的C编译器支持声明中的迭代器这样的语句(我不相信是C标准行为):

for (int i=0; i<10; ++i) 

那么你可以做以下的,它不会被认为是一个错误:

int sum = 0; 
for (int i=0; i<10; ++i) 
    for (int i=0; i<10; ++i) 
     ++sum; 

两个“我我”有不同的范围,所以它应该编译和执行得很好。