重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
宏只是在编译的时候进行替换,而不会对定义的内容进行计算,只是单纯的替换, 首先N 定义为2,M 定义为N+1, 在编译的时候,C系统就会把这里的N变为2,
创新互联建站-专业网站定制、快速模板网站建设、高性价比兴城网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式兴城网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖兴城地区。费用合理售后完善,10年实体公司更值得信赖。
下面的NUM定义为了2*M+1,在编译的时候,就直接把M变为N+1,放进去, 系统只是做了替换,
如果你用 #define N 2
#deine M (N+1)
#deine MUN 2*M+1 则可以得到MUN为2*(N+1)+1,要记住,宏只是替换,
函数式宏(function-like macro)较之对象式宏可以进行更复杂的代换。
函数式宏 sqr 是在编译时展开并填入程序的,因此 只要是能用双目运算符 * 进行乘法计算的数据类型,都能使用函数式宏 。
函数定义则需为每个形参都定义各自的数据类型,返回值的类型也只能为一种。就这点而言,函数较为严格。
函数为我们默默无闻地进行了一些复杂处理,如:
而函数式宏所做的工作只是宏展开和填入程序,并不进行上述处理。
根据以上特征, 函数式宏或许能使程序的运行速度稍微提高一点,但是程序自身却有可能变得臃肿 。
函数式宏在使用上必须小心谨慎。例如, sqr(a++) 展开后 ((a++) * (a++)) 。每次展开, a 的值都会自增两次。在不经意间表达式被执行了两次,导致程序出现预料之外的结果,我们称这种情况为宏的 副作用(side effect) 。
运行至c=fun(a,b); 这一行后
a=1,b=3,c=5
因为在fun里,a++只是对这个函数内部的参数进行自加。所以a++不影响main里的a值。但因为b是以指针传入的,所以更改的是存放b的内存单元里的值,所以main中的b值变了。c是return来的。不难理解。
运行至b=fun(c,a); 这一行后
a=7,b=13,c=5
这里c的值不变,a=(c+1); b=(c+1)+a;
运行至a=fun(b,c); 这一行后
a=29,b=13,c=15
答案是21
因为你定义的f(x) x*x ,而你下面的i=f(4+4)/(2+2)中是讲4+4作为x的值,所以展开的时候是这样的, i=4+4*4+4 /(2+2),所以结果是 i=4+16+1 ,当然是21了