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