您的位置:

c语言宏的运算,c语言宏定义计算

本文目录一览:

C语言的宏(macro)是什么?怎样使用宏?

#define VERSION—STAMP "1.02" 上例中所定义的这种形式的宏通常被称为标识符。在上例中,标识符VERSION_STAMP即代表字符串"1.02"——在编译预处理时,源代码中的每个VERSION_STAMP标识符都将被字符串“1.02”替换掉。 以下是另一个宏定义的例子: #define CUBE(x)((x),(x)*(x)) 上例中定义了一个名为CUBE的宏,它有一个参数x。CUBE宏有自己的宏体,即((x)*(x)*(x))——在编译预处理时,源代码中的每个CUBE(x)宏都将被((x)*(x)*(x))替换掉。 使用宏有以下几点好处: (1)在输入源代码时,可省去许多键入操作。 (2)因为宏只需定义一次,但可以多次使用,所以使用宏能增强程序的易读性和可靠性。 (3)使用宏不需要额外的开销,因为宏所代表的代码只在宏出现的地方展开,因此不会引起程序中的跳转。 (4)宏的参数对类型不敏感,因此你不必考虑将何种数据类型传递给宏。 需要注意的是,在宏名和括起参数的括号之间绝对不能有空格。此外,为了避免在翻译宏时产生歧义,宏体也应该用括号括起来。例如,象下例中这样定义CUBE宏是不正确的: denne CUBE(x) x * x * x 对传递给宏的参数也要小心,例如,一种常见的错误就是将自增变量传递给宏,请看下例: #include #include CUBE(x) (x * x * x) void main (void); void main (void){int x, y;x = 5;y = CUBE( + +x); printfC'y is %d\n" . y);}在上例中,y究竟等于多少呢?实际上,y既不等于125(5的立方),也不等于336(6* 7*8),而是等于512。因为变量x被作为参数传递给宏时进行了自增运算,所以上例中的CUBE宏实际上是按以下形式展开的: y = ((++x) * (++x) * (++x)); 这样,每次引用x时,x都要自增,所以你得到的结果与你预期的结果相差很远,在上例中,由于x被引用了3次,而且又使用了自增运算符,因此,在展开宏的代码时,x实际上为8,你将得到8的立方,而不5的立方。 上述错误是比较常见的,作者曾亲眼见过有多年C语言编程经验的人犯这种错误。因为在程序中检查这种错误是非常费劲的,所以你要给予充分的注意。你最好试一下上面的例子,亲眼看一下那个令人惊讶的结果值(512)。 宏也可使用一些特殊的运算符,例如字符串化运算符“#”和。连接运算符“##”。“#”运算符能将宏的参数转换为带双引号的字符串,请看下例: define DEBUG_VALUE(v) printf(#v"is equal to %d.\n",v) 你可以在程序中用DEBUG_VALUE宏检查变量的值,请看下例: int x=20; DEBUG_VALUE(x); 上述语句将在屏幕上打印"x is equal to 20"。这个例子说明,宏所使用的“#”运算符是一种非常方便的调试工具。 “##”运算符的作用是将两个独立的字符串连接成一个字符串。

C语言宏定义计算问题

答案是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了

C语言 宏的使用 比如 #define Power2(x) x*x main() { printf("%d",Power2(i+j)); } 这运算结果怎会是62?

你的i和j的值是多少?C的宏定义,在编译前,也就是预处理时会进行宏替换,就是宏体代替宏调用,其替换过程是原样照搬的。比如你的程序,带参数宏Power2(x)的宏体是"x*x“,所以在替换时,就变成了"i+j*i+j",而不是你想要的"(i+j)*(i+j)"。如果你要带括号的,则宏定义是:#define Power2(x) (x)*(x)

C语言宏定义算法

宏只是在编译的时候进行替换,而不会对定义的内容进行计算,只是单纯的替换, 首先N 定义为2,M 定义为N+1, 在编译的时候,C系统就会把这里的N变为2,

下面的NUM定义为了2*M+1,在编译的时候,就直接把M变为N+1,放进去, 系统只是做了替换,

如果你用 #define N 2

#deine M (N+1)

#deine MUN 2*M+1 则可以得到MUN为2*(N+1)+1,要记住,宏只是替换,