#include <stdio.h>
#include <stdlib.h>
#define call_optimized(function, arguments) {\
printf("\n-------------"); \
printf("\n\tCALL %s\n", #function); \
function arguments; \
printf("-------------\n"); \
}
void foo(char *str) {
printf("%s\n", str);
}
void foo2(char *str1, char *str2) {
printf("%s, %s\n", str1, str2);
}
int main(void) {
printf("FIRST call_optimized\n");
call_optimized(foo, ("hell world"));
printf("\nSECOND call_optimized");
call_optimized(foo2, ("hell", "world"));
输出(手打):
FIRST call_optimized
------------------
CALL foo
hello world
------------------
CALL foo2
hello, world
------------------
宏中 printf("\n\tCALL %s\n", #function);
输出函数名为什么要在前面加上 #
符号?求解释~
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
这里的出现在define里面的#表示一个宏的连接
传送见这里
连接符号由两个井号组成,其功能是在带参数的宏定义中将两个子串(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;
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`;
}