替换宏变量中的字符串?

Rei*_*ica 3 c macros string-concatenation stringification c-preprocessor

我有一个宏,我在其中传递一个参数并使用它根据输入的名称定义一个新变量:

#define DO_X(x) char _do_x_var_ ## x; /* other things */
Run Code Online (Sandbox Code Playgroud)

问题是如果我传入一个结构变量,它就会崩溃:

DO_X(some_struct->thing)
Run Code Online (Sandbox Code Playgroud)

变成:

char _do_x_var_some_struct->thing; /* other things */
Run Code Online (Sandbox Code Playgroud)

编辑:我希望它评估的是:

char _do_x_var_some_struct__thing; /* other things */
Run Code Online (Sandbox Code Playgroud)

(或任何包含与输入类似的内容的有效变量名称)

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

#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*/
    }
}
Run Code Online (Sandbox Code Playgroud)

但要使这些失败:

#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*/
    }
}
Run Code Online (Sandbox Code Playgroud)

有什么方法可以让这项工作发挥作用吗?也许->__什么替换?我找到了连接字符串的方法,但没有找到替换字符串的方法。

Jer*_*man 5

您还没有找到重写任意字符串的方法,因为宏无法做到这一点。宏名称必须是有效的标识符,但事实->并非如此。C 预处理器的功能非常有限。您可以寻找m4更强大的预处理器,但您可能走错了路。