C语言中的#与##字符的作用
2012-09-06 12:52
204 查看
C语言中#号和##号的使用
转载自:http://blog.21ic.com/user1/1772/archives/2007/44501.html
2
推荐
#define display(name) printf(""#name"")
int main() {
display(name);
}
运行结果是name,为什么不是"#name"呢?
---------------------------------------------------------------
#在这里是字符串化的意思
printf(""#name"") 相当于
printf("" "name" "")
---------------------------------------------------------------
The number-sign or "stringizing" operator (#) converts macro parameters (after expansion) to string constants
---------------------------------------------------------------
printf("" #name "") <1>
相当于printf("" "name" "") <2>
而<2>中的第2,3个“中间时空格 等价于("空+name+空')
---------------------------------------------------------------
## 连接符与# 符
##连接符号由两个井号组成,其功能是在带参数的宏定义中将两个子串(token)联接起来,从而形成一个新的子串。但它不可以是第一个或者最后一个子串。所谓的子串 (token)就是指编译器能够识别的最小语法单元。具体的定义在编译原理里有详尽的解释,但不知道也无所谓。同时值得注意的是#符是把传递过来的参数当成字符串进行替代。下面来看看它们是怎样工作的。这是MSDN上的一个例子。
假设程序中已经定义了这样一个带参数的宏:
#define paster( n ) printf( "token" #n " = %d", token##n )
同时又定义了一个整形变量:
int token9 = 9;
现在在主程序中以下面的方式调用这个宏:
paster( 9 );
那么在编译时,上面的这句话被扩展为:
printf( "token" "9" " = %d", token9 );
注意到在这个例子中,paster(9);中的这个”9”被原封不动的当成了一个字符串,与”token”连接在了一起,从而成为了token9。而#n也被”9”所替代。
可想而知,上面程序运行的结果就是在屏幕上打印出token9=9
---------------------------------------------------------------
#define display(name) printf(""#name"")
int main() {
display(name);
}
====================================
特殊性就在于它是个宏,宏里面处理#号就如LS所说!
处理后就是一个附加的字符串!
但printf(""#name"") ;就不行了!
---------------------------------------------------------------
#define display(name) printf(""#name"")
该定义 字符串化name,
得到结果其实就是 printf("name")
(前后的空字符串拿掉)
这样输出来的自然是 name
从另外一个角度讲,
#是一个连接符号,
参与运算了, 自然不会输出了 ...
另外还有:
#define A(x) T_##x
#define B(x) #@x
#define C(x) #x
我们假设:x=1,则有:
A(1)------)T_1
B(1)------)'1'
C(1)------)"1"
转载自:http://blog.21ic.com/user1/1772/archives/2007/44501.html
2
推荐
#define display(name) printf(""#name"")
int main() {
display(name);
}
运行结果是name,为什么不是"#name"呢?
---------------------------------------------------------------
#在这里是字符串化的意思
printf(""#name"") 相当于
printf("" "name" "")
---------------------------------------------------------------
The number-sign or "stringizing" operator (#) converts macro parameters (after expansion) to string constants
---------------------------------------------------------------
printf("" #name "") <1>
相当于printf("" "name" "") <2>
而<2>中的第2,3个“中间时空格 等价于("空+name+空')
---------------------------------------------------------------
## 连接符与# 符
##连接符号由两个井号组成,其功能是在带参数的宏定义中将两个子串(token)联接起来,从而形成一个新的子串。但它不可以是第一个或者最后一个子串。所谓的子串 (token)就是指编译器能够识别的最小语法单元。具体的定义在编译原理里有详尽的解释,但不知道也无所谓。同时值得注意的是#符是把传递过来的参数当成字符串进行替代。下面来看看它们是怎样工作的。这是MSDN上的一个例子。
假设程序中已经定义了这样一个带参数的宏:
#define paster( n ) printf( "token" #n " = %d", token##n )
同时又定义了一个整形变量:
int token9 = 9;
现在在主程序中以下面的方式调用这个宏:
paster( 9 );
那么在编译时,上面的这句话被扩展为:
printf( "token" "9" " = %d", token9 );
注意到在这个例子中,paster(9);中的这个”9”被原封不动的当成了一个字符串,与”token”连接在了一起,从而成为了token9。而#n也被”9”所替代。
可想而知,上面程序运行的结果就是在屏幕上打印出token9=9
---------------------------------------------------------------
#define display(name) printf(""#name"")
int main() {
display(name);
}
====================================
特殊性就在于它是个宏,宏里面处理#号就如LS所说!
处理后就是一个附加的字符串!
但printf(""#name"") ;就不行了!
---------------------------------------------------------------
#define display(name) printf(""#name"")
该定义 字符串化name,
得到结果其实就是 printf("name")
(前后的空字符串拿掉)
这样输出来的自然是 name
从另外一个角度讲,
#是一个连接符号,
参与运算了, 自然不会输出了 ...
另外还有:
#define A(x) T_##x
#define B(x) #@x
#define C(x) #x
我们假设:x=1,则有:
A(1)------)T_1
B(1)------)'1'
C(1)------)"1"
相关文章推荐
- C语言中的#与##字符的作用
- C语言中 ##和#的作用
- C语言宏定义中#和##的作用
- C语言宏中#和##的作用
- c语言:#和##的区别及作用
- C语言宏定义中的#和##的作用【转】
- C语言宏的高级应用 #与##作用
- c语言:键盘上回车的作用相当于\n,是一个字符
- c语言:键盘上回车的作用相当于\n,是一个字符
- C语言学习9: malloc动态内存存储,动态内存分配去空格字符增长版,动态内存分配去符号incr增长版,型参和返回值都是int型的函数的指针,main函数的地址也可以用指针指向,typedef定义函数指针,函数定义与嵌套的作用,返回函数指针类型,const作用
- C语言中##的作用
- c语言:#和##的区别及作用
- C语言宏定义中#和##的作用(需要对两片博文进行整理)
- C语言中##的作用
- C语言合法字符统计
- c语言有一字符串,包含n个字符。写一函数,将此字符串中从第m个字符开始的全部字符复制成为另一个字符串
- c语言:判断一个字符串中是否含有字符C
- C语言字符转换ASCII码
- c语言static的作用
- 在字符串中找出第一个只出现一次的字符。经典C语言例题