1.以下程序的结果是什么?
int i = 1; int main() { int i = i; return 0; }
A: main()函数里的i是一个未定义值
B: main()函数的i为1
C: 编译器不允许这种写法
D: main()里i的值为0
解答:当笔试者看到此代码时,可能会觉得古怪。虽然在C++中编译是可以通过的(显然是不合理)。当main()函数里的i从定义开始,外部的全局变量i就已经被屏蔽掉,所以main()函数里作为右值的i的值不会0也不会是1,与外部的i无关。而是一个未定义的符号。
答案:A
2.以下程序的输出结果是什么?
#include<stdio.h> int main() { int arr[]={11,12,13,14,15}; int *ptr = arr; *(ptr++) += 100; printf("%d %d\n",*ptr,*(++ptr)); return 0; }
A:13 13
B:112 13
C :12 12
D:12 13
解析:本题主要考察指针以及栈的概念 。ptr首先指向数组arr的第一个元素,*(ptr++) += 100之后,arr中的0号元素即a[0]变成了111,别忘了ptr也向后挪了一位即指向1号元素,此时*ptr的值为12。问题来了:printf(“%d %d\n”,*ptr,*(++ptr))的输出结果竟然不是12 13 而是13 13 原因在于printf的两个参数压栈顺序为从右至左,故也先计算*(++ptr),所以ptr已经指向了arr[2],所以两次都是13
答案:A
3. 以下代码说法正确的是:
#include<stdio.h> int main(void) { char aChar; int aInt; aInt = aChar = -120; printf("%d\n",aInt); return 0; }
A:一定输出-120
B:一定不能输出-120
C:可能输出-120
D:输出%d
解答:本题乍一看,-120木有问题! 再仔细一看 char类型表示的数据范围是-128~127,也没有溢出。应该没错咯。但本题考查的重点并非在此。重点在于aInt = aChar = -120;这句话,为什么呢?我们知道=号的意思是赋值,是从右往左运算,那第一步会将-120赋给aChar。第二步是aChar的值给aInt。对于第一步没有什么要说的。第二步呢就有个问题了。以32位系统常规平台来看,是将8字节数据的char类型变量放到32个字节的int变量里去,那这里就存在一个问题了!没错,那就是大小端存储导致的问题,即-120这个数字对应的八个位的二进制码是放到int变量的高位还是低位,所以结果自然不必多说了。
答案:C
C语言研究中心(www.dotcpp.com)