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
  #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").
--------------------- 
作者:2222345345 
来源:CSDN 
原文:https://blog.csdn.net/ftell/article/details/79376200 
版权声明:本文为博主原创文章,转载请附上博文链接!

你可能感兴趣的:(c++)