笔试面试题记录(0x01) —— #define

本文通过一道笔试题分析了宏定义#define的工作原理,强调了在宏替换时不进行额外计算的重要性。错误的理解导致选择了错误的答案,正确的解答需要考虑运算符的优先级。文中还给出了多个关于#define的题目及解析,探讨了宏定义与函数的不同,并提醒在宏定义中使用括号以避免二义性。
摘要由CSDN通过智能技术生成

一直感觉自己明白#define是怎么回事

直到迪普笔试遇到这道题:

设有以下宏定义
#define N 3 
#define Y(n) ((N+1)*n) 
则执行语句:z=2*((N+Y(5+1));后,z的值为(    )。        
A、 出错  
B、 42  
C、 48  
D、 54

define, 宏定义

define在程序运行之前,编译预处理时, 替换

比如:#define PI 3.1415926

在程序编译预处理的时候,将会把程序中所有的PI都替换成3.1415926

这样写的好处有很多, 比如可以方便程序修改, 在程序中用PI代替3.1415926这串数字也增加了程序的可读性



我觉得也许我的C根本没入门

当时觉得 2*(N+Y(5+1)) == 2 *(3 + (3 + 1) * 6) == 2 * 27 == 54

选了D

后来面试我的人,问我,这样define的写法, 和写成函数形式的区别

我答:define是在运行之前替换,而函数是运行时调用, 巴拉巴拉巴拉...

他说:那你怎么没直接替换呢?..

我    :......

他说:下次注意就行了,小问题。( 他以为我懂,以为我是笔误呢)

其实面试结束我也不明白我错哪了, 呵呵。


后来回到家里, 从网上看到了这道题, 才明白自己到底错在哪了


#define  就是在运行之前替换, 替换就是替换, 你就只需要替换就行

不需要做多余的操作 , 比如上题中, 我自己把 5 + 1 求出来了

替换就是替换, 替换就是替换, 替换就是替换, 所以你只需要替换即可

无论需要替换的是一个数字, 还是一个表达式

所以我们应该把 5+1 代替 Y(n)中的n , 而不是6

所以, 2*(N+Y(5+1)) ==

这段代码有几个错误: 1. 缺少头文件:此代码使用了一些特定的寄存器和函数,需要包含对应的头文件。常用的头文件有"reg51.h"和"8051.h",需要添加其中一个头文件。 2. delay函数没有实现:在delay函数的定义后面没有实现具体的延时功能,需要在函数体内添加具体的延时实现。 3. 宏定义错误:在宏定义中,应该使用位运算或者逻辑运算来设置对应的位,而不是使用按位或运算。例如,P2_0应该定义为P2 & 0x01。 4. 函数声明错误:在函数声明中,需要指定函数的返回类型。例如,void delay(unsigned int xms)应该改为unsigned int delay(unsigned int xms)。 5. EXTI0_Handler函数中的代码错误:在此函数中,应该判断P2_0是否为0,而不是是否为1。 6. INT1_Init函数中的中断类型错误:在此函数中,应该指定中断类型为下降沿触发,而不是上升沿触发。例如,IT1=EXTI1_IT_FALLING。 正确的代码应该是这样的: ``` #include <reg51.h> #include <intrins.h> #define uchar unsigned char #define uint unsigned int #define P2_0 (P2 & 0x01) #define P2_1 (P2 & 0x02) #define P2_2 (P2 & 0x04) #define P2_3 (P2 & 0x08) #define P2_4 (P2 & 0x10) #define P2_5 (P2 & 0x20) #define P2_6 (P2 & 0x40) #define P2_7 (P2 & 0x80) #define P0_0 (P0 & 0x01) #define P0_1 (P0 & 0x02) #define P0_2 (P0 & 0x04) #define P0_3 (P0 & 0x08) #define P0_4 (P0 & 0x10) #define P0_5 (P0 & 0x20) #define P0_6 (P0 & 0x40) #define P0_7 (P0 & 0x80) #define EXTI0_IT_RISING 0x01 #define EXTI1_IT_FALLING 0x02 unsigned int delay(unsigned int xms) { unsigned int i,j; for(i=xms;i>0;i--) for(j=110;j>0;j--); return xms; } void INT0_Init(void); void INT1_Init(void); void EXTI0_Handler(void); void EXTI1_Handler(void); void main(void) { P2=0x00; EXTI0_Init(); EXTI1_Init(); while(1) { if(P2_0==1) { delay(500); P2=~P2; } } } void INT0_Init(void) { IT0=EXTI0_IT_RISING; EX0=1; EA=1; } void INT1_Init(void) { IT1=EXTI1_IT_FALLING; EX1=1; EA=1; } void EXTI0_Handler(void) { if(P2_0==0) { P0=_crol_(_cror_(P0,7),1); } } void EXTI1_Handler(void) { if(P2_1==1) { delay(500); P2=~P2; } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值