#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
#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"
).