- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
程序员求职真题预处理和内存管理
第12章
预处理和内存管理
预处理是C和C++语言独有的特色,它允许开发人员定义
宏,编译器在编译文件时会首先进行一次预编译,将宏替换为
实际定义的内容。许多公司的面试题中都或多或少涉及一些预
处理相关的面试题。而内存管理是编程必须掌握的内容,自然
也是各公司面试题中必有的内容。在本章中详细列举了这两方
面的面试题,并进行了深入剖析,加深求职者对预处理和内容
管理的理解,做到举一反三。
12.1 宏定义
面试真题1:定义一个宏实现两个数的交换 (思科面试题)
高频考点:
考点分析:
本题实际考察面试人员的两项内容。一是对宏的理解和掌握。二是对基
本算法的掌握。许多面试人员感觉此题非常容易,马上就写出了代码。例如:
#defineswap(x,y)intz=x;x=y;y=z
这样的代码实现了面试题的功能,但是存在一定缺陷。例如,如果程序
中已经定义了变量z,那么使用swap宏时,编译就会出现错误。例如:
intmain(intargc,char*argv[])
{
intz,a=5,b= 10;
swap(a,b);
printf(%d,%d,a,b);
return0;
}
编译上述代码将出现 “errorC2086:z:redefinition”错误。因为局部变
量z被重复定义。所以在定义宏时应尽量避免定义额外的变量。在本例中就
需要实现不借助第3方变量实现两个数值的互换。方法为:
x=x+y;y=x-y;x=x-y;
参考答案:
#defineswap(x,y)x=x+y;y=x-y;x=x-y
面试真题2:简述含参数的宏与函数的差别(SONY面试题)
高频考点:
考点分析:
许多书中介绍宏时,都会将宏与常量进行比较。而本题是宏与函数的比
较。其实,这两者之间有许多共同点。例如,程序中使用常量会进行类型检
查,同理使用函数也会进行函数参数和返回值的类型检查,而宏则不进行类
210
型检查。
在回答本题时只要体现出两个重点就可以了。一是对宏的理解。重点是
宏如何被编译的。编译器在编译代码时,首先会检查代码中是否有宏,如果
有,会将宏转换为宏定义的内容,也就是进行代码替换。然后再对代码进行
编译。二是程序中使用宏,编译器不会进行类型检查,而函数则会进行类型
检查。
参考答案:
(1)宏是编译期进行的,编译器在编译程序时,首先进行预编译,也
就是将代码中的宏替换为宏定义的内容。而函数是运行期进行的。
(2)程序中使用宏时不会进行参数类型检查,而函数则会进行参数类
型检查。
(3)宏只是编译期进行替换,在程序中遇到swap(a,b)宏时,就用 “x=
x+y;y=x-y;x=x-y;”代替,x和y两个实体并没有由宏实际产生,而函
数会在栈中定义局部变量和函数参数。
(4)宏没有生存期、作用域之类的概念,而函数则有。
面试真题 :编写一个宏MIN,返回两个数的较小者
高频考点:
考点分析:
许多面试者看到类似的题目时,都会毫不犹豫的写出类似下面的定义。
#defineMIN(x,y)(xy?y:x)
这实际是一种错误的写法,在面试过程中这样的答案是不会得分的。因
为编译器在预编译时只是将出现宏的地方进行文本替换。如果使用下面的代
码调用宏MIN,会出现副作用。
MIN(a0x10,b);
程序的实际代码为:
a0x10b?b :a0x10;
运算符的优先级低于运算符的优先级,因此结果通常不是我们所预期
的。
在本题中也有人采用如下的形式回答。
#defineMIN(x,y)((x)(y)?(y):(x));
211
这种答案最接近标准答案,但
文档评论(0)