美文网首页
宏定义中的#和##

宏定义中的#和##

作者: WebSSO | 来源:发表于2017-09-13 15:04 被阅读15次

    http://www.cnblogs.com/mydomain/archive/2010/09/25/1834917.html

    在一个预处理器宏中的参数前面使用一个#,预处理器会把这个参数转换为一个字符数组

    #是“字符串化”的意思。出现在宏定义中的#是把跟在后面的参数转换成一个字符串

    > #define STRCPY(dst, src)  strcpy(dst, #src)

    > STRCPY(buff, abc)

    相当于strcpy(buff, "abc")

    如果##后的参数本身也是一个宏的话,##会阻止这个宏的展开,也就是只替换一次

    #define STRCPY(a, b)    strcpy(a ## _p, #b)

    /*注意这里*/

    STRCPY(STRCPY(var1,var2),var2);

    /*这里是否会展开为:strcpy(strcpy(var1_p,"var2")_p,"var2“)?

    *答案是否定的:

    *展开结果将是:strcpy(STRCPY(var1,var2)_p,"var2")

    * ##阻止了参数的宏展开!

    *如果宏定义里没有用到#和##,宏将会完全展开

    */

    简单的说,“##”是一种分隔连接方式,它的作用是先分隔,然后进行强制连接。

    其中,分隔的作用类似于空格。我们知道在普通的宏定义中,预处理器一般把空格解释成分段标志,对于每一段和前面比较,相同的就被替换。但是这样做的结果是,被替换段之间存在一些空格。如果我们不希望出现这些空格,就可以通过添加一些##来替代空格。

    相关文章

      网友评论

          本文标题:宏定义中的#和##

          本文链接:https://www.haomeiwen.com/subject/uhzksxtx.html