#define宏定义

对以下程序,正确的输出结果是()

#include 
#include 

#define SUB(x,y) x - y
#define ACCESS_BEFORE(element, offset, value) *SUB(&element, offset) = value

using namespace std;

int main() {
    int i;
    int array[10] = {1,2,3,4,5,6,7,8,9,10};
    ACCESS_BEFORE(array[5], 4, 6);
    for(i = 0; i < 10; i++) {
        cout<<array[i]<return 0;
} 

A array: 1 6 3 4 5 6 7 8 9 10
B array: 6 2 3 4 5 6 7 8 9 10
C 程序可以正确编译连接,但是运行时会崩溃
D 程序语法错误,编译不成功

解析:宏定义被替换成了:*&array[5] - 4 = 6
&array[5]表示array[5]的地址
*&array[5]表示array[5]
相当于array[5] - 4 = 6,由于左边是一个表达式,在赋值表达式中,左值必须是一个可修改的内存块,而上述式子的左值是一个字面值常量,这是编译不能通过的,所以编译会报错。

C语言编译分为预编译,编译,链接,最后形成可执行文件,宏替换在预编译阶段进行,不进行语法的检查,但是编译阶段会对每一表达式的合法性进行检查。

如果想让程序正确的运行,需要将宏定义部分改为:

#define SUB(x,y) (x - y)
#define ACCESS_BEFORE(element, offset, value)*SUB(&element, offset) = value

宏定义部分相当于被替换成了:*(&array[5] - 4) = 6
array[5]的地址上向前移动4位,即array[1] = 6
所以程序运行的结果为:1 6 3 4 5 6 7 8 9 10

#define 定义min函数

#define MIN(A, B) ((A) <= (B) ? (A) : (B))

注意事项:
1. #define定义的函数会直接嵌入到代码中
2. 三重条件操作符?: 代替if
3. 在宏定义中,用括号把参数小心地括起来
4. 不能以分号结束

转载链接:https://blog.csdn.net/u010429424/article/details/74147588?locationNum=1&fps=1

你可能感兴趣的:(面试题解析)