C++/C宏定义中## 连接符与# 符的含义
2015-06-25 21:35
204 查看
1./article/8942420.html
2.http://www.yunsec.net/a/school/ymbc/C/2009/1027/1243.html
## 连接符号由两个井号组成,其功能是在带参数的宏定义中将两个子串(token)联接起来,从而形成一个新的子串。但它不可
以是第一个或者最后一个子串。所谓的子串(token)就是指编译器能够识别的最小语法单元。具体的定义在编译原理里有详尽的
解释,但不知道也无所谓。同时值得注意的是#连接符是把传递过来的参数当成字符串进行替代。下面来看看它们是怎样工作
的。这是MSDN上的一个例子。
假设程序中已经定义了这样一个带参数的宏:
#define paster( n ) printf( "token" #n " = %d", token##n )
同时又定义了一个整形变量:
int token9 = 9;
现在在主程序中以下面的方式调用这个宏:
paster( 9 );
那么在编译时,上面的这句话被扩展为:
printf( "token" "9" " = %d", token9 );
详细解说:#n 相当于 “n”, token##n 相当于token9,须注意##不能当成两个#,他们意义是不同的。
注意到在这个例子中,paster(9);中的这个”9”被原封不动的当成了一个字符串,与”token”连接在了一起,从而成为了
token9。而#n也被”9”所替代。
可想而知,上面程序运行的结果就是在屏幕上打印出token9=9
注意##和#的使用场合,不能乱用。
# —— 字符串
##——连接两个参数
实例:
[/code]
C++/C宏定义中## 连接符与# 符的含义
转自:1./article/8942420.html
2.http://www.yunsec.net/a/school/ymbc/C/2009/1027/1243.html
## 连接符号由两个井号组成,其功能是在带参数的宏定义中将两个子串(token)联接起来,从而形成一个新的子串。但它不可
以是第一个或者最后一个子串。所谓的子串(token)就是指编译器能够识别的最小语法单元。具体的定义在编译原理里有详尽的
解释,但不知道也无所谓。同时值得注意的是#连接符是把传递过来的参数当成字符串进行替代。下面来看看它们是怎样工作
的。这是MSDN上的一个例子。
假设程序中已经定义了这样一个带参数的宏:
#define paster( n ) printf( "token" #n " = %d", token##n )
同时又定义了一个整形变量:
int token9 = 9;
现在在主程序中以下面的方式调用这个宏:
paster( 9 );
那么在编译时,上面的这句话被扩展为:
printf( "token" "9" " = %d", token9 );
详细解说:#n 相当于 “n”, token##n 相当于token9,须注意##不能当成两个#,他们意义是不同的。
注意到在这个例子中,paster(9);中的这个”9”被原封不动的当成了一个字符串,与”token”连接在了一起,从而成为了
token9。而#n也被”9”所替代。
可想而知,上面程序运行的结果就是在屏幕上打印出token9=9
注意##和#的使用场合,不能乱用。
# —— 字符串
##——连接两个参数
实例:
#include<iostream>using namespace std;
[/code]
#define TEST(pid) (cout<<para##pid<<endl)
#define TEST2(p) (cout<<#p<<endl)
int _tmain(int argc,TCHAR ** argv)
{
int para3 = 3;
int para2 = 2;
TEST(2); //cout<<para2<<endl; 输出:2
TEST(3); //cout<<para3<<endl; 输出:3
TEST2(test) ;//cout<<"test"<<endl; 输出:test
TEST2("test2"); //cout<<""test2""<<endl; 输出:“test2”
return 1;
}
相关文章推荐
- C++的常量
- C++文件操作详解(ifstream、ofstream、fstream)
- C++中相对路径与绝对路径以及斜杠与反斜杠的区别
- C++实现顺序队列
- C++头文件定义规则
- C语言关键字
- C++ 一些常用函数的使用(1)
- C++13.1.2合成复制构造函数----定义复制对象时会发生什么
- 微软100题
- [LeetCode] Jump Game II
- C与C++代码互相访问
- 微软100题第46题:四对括号可以有多少种匹配排列方式?
- 北大百炼1006 Biorhythms 题解
- 北大百炼1005 I Think I Need a Houseboat题解
- 北大百炼1004 Financial Management 题解
- c++11 移动语意 gcc 实测
- 俄罗斯方块(C语言)
- C++ Primer 学习笔记_9_标准库类型(续3) -- biteset
- C++ Primer 学习笔记_8_标准库类型(续2) -- iterator
- C++ Primer 学习笔记_7_标准库类型(续1) -- vector类型