第一题
1. 有以下程序段:
char *p, *q; p = (char *)malloc(sizeof(char) * 20); q = p; scanf("%s %s", p, q); printf("%s %s\n", p, q);
若从键盘输入:abc def↙,则输出结果是( )
A:def def
B:abc def
C:abc d
D:d d
答案及解析 A
首先本题考查的是我们对指针的认识,指针指向哪里,然后赋值的顺序之类的;
所以我们先看下面的图:
我们首先知道,p和q这两个指针都是指向的这段空间,但是输入的时候,记住都是从低地址开始的,所以p和q的起始位置是一样的,那么必定会发生覆盖,也就是先输入的会被覆盖,那么p输入了abc,然后scanf会以空格作为分隔符,遇到空格就会默认当前输入结束,切换下一个输入,然后q输入def,同样scanf也会以\n作为分隔符,结束当前输入;所以abc被def覆盖了,那么printf打印出来的p和q,就是同一个字符串def
第二题
2. 在程序代码中写的注释太多,会使编译后的程序尺寸变大。
A:正确
B:错误
答案及解析 B
本题就是考查大家对程序的翻译环境的认识,注释是在预处理阶段就被删除了,所以编译之后压根就不会存在注释这个东西,尺寸还缩小了;
第三题
3. 下列程序执行后的输出结果是 ____
#include <stdio.h> void func(int *a, int b[]) { b[0] = *a + 6; } int main() { int a = 0; int b[5]; b[0] = 3; func(&a, b); printf("%d\n", b[0]); return 0; }
A:6
B:7
C:8
D:9
答案及解析 A
本题是考查传址会不会对变量本身有改变;答案是肯定会的;参数传地址的好处就是可以改变实参,而传值就不会改变实参,传值是拷贝一个临时变量,传地址就是把实参的地址传过去;
所以我们数组b的第一个元素在函数func中就会被改变成*a + 6;而*a = 0;所以b[0] = 6;
第四题
4. 下面程序段的运行结果是()
#include <stdio.h> int main() { char *s = "abcdefg"; s += 2; printf("%d\n", s); return 0; }
A:cde
B:字符"c"
C:字符"c"的地址
D:不确定
答案及解析 C
本题考查的是你对数组名的理解,首先数组名表示的是首元素地址,所以s是表示的首元素地址,也就是a的地址,然后对s += 2;也就是s向后移动2个字节的大小,到达的是c 的地址;
格式化打印也是打印的%d,就是打印c的地址;如果换成%s,就是打印出cdefg。
记住printf函数打印字符串的时候,遇到\0就会停止打印。
第五题
5. 程序运行后的输出结果是()
#include <stdio.h> int main() { int a[3][3], *p, i; p = &a[0][0]; for(i = 0; i < 9; i++) p[i] = i; for(i = 0; i < 3; i++) printf("%d ", a[1][i]); return 0; }
A:0 1
B:1 2 3
C:2 3 4
D:3 4 5
答案及解析 D
本题考查你对数组的理解,p是这个二维数组的第一个元素的地址,所以第一个for循环的作用是给二维数组的每个元素都赋值,那 p[ i ] 相当于*(p + i)也就是到达每一个元素的位置,之后解引用取出该元素并赋值,所以打印出来的就是D