最近在阅读大佬们写的开源库的时候,看到一些宏定义,不是很明白它的用法,就查了很多资料,弄清楚它们的用法后,在这里记录一下。
(1)#的作用
#param指把param当成符号,就是把#后面的看成字符串
#define TEST1(param) #param
#include <iostream>
int main(int argc, char *argv[])
{
const char *pStr0 = TEST1("123");
const char *pStr1 = TEST1(123);
std::cout << pStr0 << std::endl;
std::cout << pStr1 << std::endl;
getchar();
return 0;
}
运行结果:
"123"
123
(2)##的使用
##在宏里面相当于连接符,把前后两个字符串连回在一起作为一个字符串
在vs编译器中
#define TEST2(param1,param2) (param1##param2)
#include <iostream>
int main(int argc, char *argv[])
{
int num = TEST2(12, 34);
const char *pStr2 = TEST2("12", "34");
std::cout << num << std::endl;
std::cout << pStr2 << std::endl;
getchar();
return 0;
}
而在gcc编译器却有不同
#define TEST2(param1,param2) (param1 param2)
#include <iostream>
int main(int argc, char *argv[])
{
// int num = TEST2(12, 34); //gcc编译下会报错
// std::cout << num << std::endl;
const char *pStr2 = TEST2("12", "34");
std::cout << pStr2 << std::endl;
getchar();
return 0;
}
在vs中
#define TEST2(param1,param2) (param1##param2)
在gcc中,注意后面的(param1 param2)中间有空格
#define TEST2(param1,param2) (param1 param2)
我们继续看一个例子:
在vs编译器下:
#define f(a,b) a##b
#define d(a) #a
#define s(a) d(a)
#include <iostream>
using namespace std;
int main()
{
std::cout << d(f(a, b)) << std::endl;
std::cout << s(f(a, b)) << std::endl;
getchar();
return 0;
}
运行结果:
f(a, b)
ab
解释:
1,不以"#"开头的,先展开参数a,然后是替换代码:
s(f(a,b))–>s(ab)–>d(ab)–>“ab”
2,以"#"开头的,直接替换,不展开:d(f(a,b))–>“f(a,b)”
关于这个例子更多的解释,具体可以参考:#define中#和##的作用