由宏定义来实现求两个数的乘积和商数之笔试实例

时间:2020-11-21 17:39:47 笔试题目 我要投稿

由宏定义来实现求两个数的乘积和商数之笔试实例

  解:#include

由宏定义来实现求两个数的乘积和商数之笔试实例

  main()

  #define product(a,b) (a*b)

  #define divide(a,b) (a/b)

  {

  float result,n1,n2;

  printf(“input n1:”);

  scanf(“%f”,&n1);

  printf(“input n2:”);

  scanf(“%f”,&n2);

  result=product(n1,n2);

  printf(“%f\n”,result);

  result=divide(n1,n2);

  printf(“%f/n”,result);

  }
拓展:

  带参数的宏定义的一般形式如下:

  #define <宏名>(<参数表>) <宏体>

  其中, <宏名>是一个标识符,<参数表>中的参数可以是一个,也可以是多个,视具体情况而定,当有多个参数的时候,每个参数之间用逗号分隔。<宏体>是被替换用的字符串,宏体中的字符串是由参数表中的各个参数组成的表达式。例如:

  #define SUB(a,b) a-b

  如果在程序中出现如下语句:

  result=SUB(2, 3);

  则被替换为:

  result=2-3;

  如果程序中出现如下语句:

  result= SUB(x+1, y+2);

  则被替换为:

  result=x+1-y+2;

  在这样的宏替换过程中,其实只是将参数表中的参数代入到宏体的表达式中去,上述例子中,即是将表达式中的a和b分别用2和3代入。

  我们可以发现:带参的宏定义与函数类似。如果我们把宏定义时出现的参数视为形参,而在程序中引用宏定义时出现的参数视为实参。那么上例中的a和b就是形参,而2和3以及x+1和y+2都为实参。在宏替换时,就是用实参来替换<宏体>中的形参。

  注意问题

  在使用宏定义时应注意的是:

  (a) 在书写#define 命令时,注意<宏名>和<字符串>之间用空格分开,而不是用等号连接。

  (b) 使用#define定义的标识符不是变量,它只用作宏替换,因此不占有内存。

  (c) 习惯上用大写字母表示<宏名>,这只是一种习惯的约定,其目的是为了与变量名区分,因为变量名

  通常用小写字母。

  如果某一个标识符被定义为宏名后,在取消该宏定义之前,不允许重新对它进行宏定义。取消宏定义使用如下命令:

  #undef<标识符>

  其中,undef是关键字。该命令的功能是取消对<标识符>已有的宏定义。被取消了宏定义的标识符,可以对它重新进行定义。

  宏定义可以嵌套,已被定义的标识符可以用来定义新的标识符。例如:

  #define PI 3.14159265#define R 10#define AREA (PI*R*R)注意事项

  在使用带参数的宏定义时需要注意的是:

  (1)带参数的宏定义的`<宏体>应写在一行上,如果需要写在多行上时,在每行结束时,使用续行符 "\"结

  束,并在该符号后按下回车键,最后一行除外。

  (2)在书写带参数的宏定义时,<宏名>与左括号之间不能出现空格,否则空格右边的部分都作为宏体。

  例如:

  #define ADD (x,y) x+y

  将会把"(x,y)x+y"的一个整体作为被定义的字符串。

  (3)定义带参数的宏时,宏体中与参数名相同的字符串适当地加上圆括号是十分重要的,这样能够避免

  可能产生的错误。例如,对于宏定义:

  #define SQ(x) x*x

  当程序中出现下列语句:

  m=SQ(a+b);

  替换结果为:

  m=a+b*a+b;

  这可能不是我们期望的结果,如果需要下面的替换结果:

  m=(a+b)*(a+b);

  应将宏定义修改为:

  #define SQ(x) (x)*(x)

  对于带参的宏定义展开置换的方法是:在程序中如果有带实参的宏(如"SUB(2,3)"),则按"#define"命令行中指定的字符串从左到右进行置换。如果串中包含宏中的形参(如a、b),则将程序语句中相应的实参(可以是常量、变量或者表达式)代替形参,如果宏定义中的字符串中的字符不是参数字符(如a-b中的-号),则保留。这样就形成了置换的字符串。

  (4) 定义带参数的宏后,使用时最好避免使用表达式传参。这样可以在复杂的宏定义中避免(3)中出现的问题

【由宏定义来实现求两个数的乘积和商数之笔试实例】相关文章:

笔试实例:求∏的近似值11-21

笔试实例:写出一个方法实现冒泡排序11-22

局域网定义和特性笔试题11-19

javascript定义类和类的实现举例说明11-12

JavaScript类定义原型方法的两种实现的区别11-22

关于JAVA实现httpClient的实例10-08

C++笔试实例分析11-22

javascript闭包的定义及应用实例分析11-20

PHP实现RSA加密类的实例解析11-25