第 1 题
🎗如下代码的输出结果是
#pragma pack(4)/*编译选项,表示4字节对齐 平台:VS2017。语言:C语言*/ int main(int argc, char* argv[]) { struct tagTest1 { short a; char d; long b; long c; }; struct tagTest2 { long b; short c; char d; long a; }; struct tagTest3 { short c; long b; char d; long a; }; struct tagTest1 stT1; struct tagTest2 stT2; struct tagTest3 stT3; printf("%d %d %d", sizeof(stT1), sizeof(stT2), sizeof(stT3)); return 0; } #pragma pack()
📝 分析:
根据结构体的内存对齐可得
所以输出结果是 12Byte, 12Byte, 16Byte
第 2 题
🎗 有如下代码,请问 enumA = _____ ; enumB = ______ ;
enum ENUM_A { X1, Y1, Z1 = 5, A1, B1 }; enum ENUM_A enumA = Y1; enum ENUM_A enumB = B1;
📝 分析:
此题考查的是枚举关键字的特性
1️⃣ 枚举的成员是可能取值、也叫枚举常量,默认是从 0 开始
2️⃣ 枚举常量值是可以修改的,且会按照最后修改的值往后递增。在定义枚举时是赋初值 (默认是从0开始) ,当然出了枚举外部去修改时是 err
所以 enumA = 1;enumB = 7;
第 3 题
🎗 以下程序的输出结果是____
#include<stdio.h> int fun(int x, int y) { static int m = 0; static int i = 2; i += m + 1; m = i + x + y; return m; } void main() { int j = 4; int m = 1; int k; k = fun(j, m); printf("%d,", k); k = fun(j, m); printf("%d/n", k); return; }
📝 分析:
此题是对 Static 关键字的考查,static 可以修饰局部变量、全局变量、函数
1️⃣ static 修饰局部变量,改变了局部变量的生命周期 (本质上是改变了变量的存储类型),局部变量由栈区转向静态区,生命周期同全局变量一样
2️⃣ static 修饰全局变量,使得这个全局变量只能在自己所在的文件内部使用,而普通的全局变量却是整个工程都可以使用
❓ 为什么全局变量能在其它文件内部使用 ❔
因为全局变量具有外部链接属性;但是被 static 修饰后,就变成了内部链接属性,其它源文件不能链接到这个静态全局变量了
3️⃣ static 修饰函数,使得函数只能在自己所在的文件内部使用,本质上 static 是将函数的外部链接属性变成了内部链接属性 (同 static 修饰全局变量)
❗ C/C++内存区域划分示意图 ❕
所以输出结果是 8, 17
第 4 题
🎗如下程序结果运行结果是 ____
int Change(int *pX) { int y = 8; y = y - *pX; pX = &y; return 0; } int main() { int xx = 3; int *pY = &xx; Change(pY); printf("%d\n", *pY); return 0; }
A. 8
B. 3
C. 5
D. 不确定
📝 分析:
函数传参有两种形式
1️⃣ 值传递,函数的形参和实参分别是两块不同的空间,对形参的修改不会影响实参
2️⃣ 址传递,传址调用是把函数外部创建变量的内存地址传递给函数参数的一种调用函数的方式,这种方式可以和函数外的变量建立起真正的联系,也就是函数内部可以直接操作函数外部的变量
在 Change 里想要对 pY 的地址改变就需要传二级指针
所以选择 B
第 5 题
🎗.下列程序执行后的输出结果是 ____
int main() { char arr[2][4]; strcpy((char*)arr,"you"); strcpy(arr[1],"me"); arr[0][3] = '&'; printf("%s\n",arr); return 0; }
A. you&me
B. you
C. me
D. err
📝 分析:
所以选择 A 选项