1.下面的代码输出什么?为什么?

void foo(void)

{

unsigned int a = 6;

int b = -20;

(a+b > 6)?puts(“>6”):puts(“<=6”);

}

答案:输出值”>6”

解析:a+b在这里做了隐式的转换,把int转化为unsigned int.编译器会把b当做一个很大的正数.

2.下面的代码有什么问题,为什么?

void foo(void)

{

    char string[10], str1[10];

    int i;

    for (i = 0; i < 10; i++) {

        str1[i] = 'a';

    }

    strcpy(string, str1);

    printf("%s\n", string);

}

答案:运行到strcpy的时候可能会产生内存异常

解析:吟哦日str1没有\0结束标志,所以数组后面存储的可能不是\0,而是随机数据,对于strcpy和printf这种需要\0判断字符串结束的函数来说,出错是必然的了.

道理虽是如此,但是这段代码我在windows和Linux下测试的结果不一样,Linux下可以正常输出10个a,windows下会出错,使用的都是gcc的编译器.

3.下面的代码,i和j的值分别是多少?为什么?

static int j;

int k = 0;

void fun1(void)

{

    static int i = 0;

    i++;

}

void fun2(void)

{

    j = 0;

    j++;

}

int main(void)

{

    for (k = 0; k < 10; k++) {

        fun1();

        fun2();

    }

    return 0;

}

答案:i=10,j=1

解析:由于被static修饰的局部变量存储在静态区内,所以即使这个函数运行结束,这个静态变量还是不会被销毁,函数下次运行时还能使用这个值,静态变量只被初始化一次,函数下次运行会直接跳过初始化,进行++操作.而j每次都被赋0.

4.下面的代码里,假设在32位系统下,各sizeof计算得结果分别是多少?

int *p = NULL;

sizeof(p)的值是

sizeof(*p)的值是

int a[100];

sizeof(a)的值是

sizeof(a[100])的值是

sizeof(&a)的值是

sizeof(&a[0])的值是

int b[100];

void fun(int b[100])

{

    sizeof(b);

}

sizeof(b)的值是

答案:4,4,400,4,4,4,4

解析:没什么好说的吧

5.下面代码的结果是多少?为什么?

int main(void)

{

    char a[1000];

    int i;

    for (i = 0; i < 1000; i++)

        a[i] = -1-i;

    printf("%d", strlen(a));

    return 0;

}

答案:255

解析:基本上算是个”轮回”的问题,strlen遇到a[i]=0的时候就终止了,现在的问题变成循环多少次a[i]=0了,那么就使用补码来计算到底多少次之后char会溢出为0,我的回答是一个轮回,也就是256次,那么strlen不包含0的位置,那么长度就是255了.