C++ ## 和 #

#define   SUITEK_DECLARE_TEST(class_name, attributes) \
   public: \
      virtual SUITEK_CTestClassInfo* GetTestClassInfo() const; \
      static SUITEK_CTest* TestFactory(); \
      static void CreateParams( SUITEK_CTestClassInfo* pInfo ); \
      static SUITEK_CTestClassInfo ms_Info##class_name;

#define   SUITEK_IMPLEMENT_TEST(class_name, version) \
   SUITEK_CTest* class_name::TestFactory() \
      { return new class_name; } \
   SUITEK_CTestClassInfo* class_name::GetTestClassInfo() const \
      { return &class_name::ms_Info##class_name; } \
   SUITEK_CTestClassInfo class_name::ms_Info##class_name( \
         class_name::TestFactory, \
         class_name::CreateParams, \
         #class_name, #version);

假定 class_name 是 CMyClass,那么 #class_name = “CMyClass”, #就是将参数变成字符串。

而## 则是连接作用,是省略:ms_Info##class_name = ms_infoCMyClass

Stackoverflow上的例子:

  #include <stdio.h>
  #define f(a,b) a##b
  #define g(a)   #a
  #define h(a) g(a)

  int main()
  {
    printf("%s\n",h(f(1,2)));
    printf("%s\n",g(f(1,2)));
    return 0;
  }

运行结果:

12
f(1,2)

h(f(1, 2)) -> h(12) -> g(12) -> "12"

g(f(1, 2)) -> "f(1, 2)"

在 function-like 宏里出现的参数, 除非它是 ### 的操作数, 在替换之前先进行扩展, 然后重新扫描整个表达式进行下一步扩展。 因为 g 的参数 # 的操作数, 参数不扩展而是立即字符串化 ("f(1,2)"). 因为 h 的参数既不是  # 也不是 ## 的操作数, the 参数首先扩展为(12), 然后进行替换 (g(12)), 然后重新扫描得到表达式 ("12").

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值