c语言面试题

来源:互联网 发布:部落冲突 模拟软件 编辑:程序博客网 时间:2024/06/06 19:52

1、下面的代码输出的结果是什么,并简单分析结果。

[cpp] view plain copy
print?
  1. #include <stdio.h>  
  2.   
  3. //无符号数与有符号数相加  
  4.   
  5. int main(int argc, char **argv)  
  6. {  
  7.     unsigned int a = 6;  
  8.     int b = -12;  
  9.     if(a+b > 0)  
  10.     {   
  11.         printf(”dsds\n”);  
  12.         printf(”a+b=%d\n” , a+b);  
  13.         printf(”a+b=%p\n” , (void *)(a+b));  
  14.     }  
  15.     else  
  16.     {  
  17.         printf(”ssss\n”);  
  18.         printf(”a+b=%d\n” , a+b);  
  19.         printf(”a+b=%p\n” , (void *)(a+b));  
  20.     }  
  21.     return 0;  
  22. }  
#include <stdio.h>//无符号数与有符号数相加int main(int argc, char **argv){    unsigned int a = 6;    int b = -12;    if(a+b > 0)    {         printf("dsds\n");        printf("a+b=%d\n" , a+b);        printf("a+b=%p\n" , (void *)(a+b));    }    else    {        printf("ssss\n");        printf("a+b=%d\n" , a+b);        printf("a+b=%p\n" , (void *)(a+b));    }    return 0;}
答案:
dsds
a+b=-6
a+b=0xFFFFFFFA

原因:当无符号数与有符号数相加时,将相加后的结果转化为无符号数,为什么第一个结果是-6呢,因为%d输出的时候是按照有符号数输出的。第二个输出语句就是按照内存里的内容输出的。为什么是0xFFFFFFFA,-6的补码就是0xFFFFFFFA,计算机在内存中存储数据的格式是补码的格式,所以打印出来的结果就是一个大于0的数。这就充分说明了a+b>0了。

2、下面的函数有什么错误:

[cpp] view plain copy
print?
  1. int square(volatile int *ptr)  
  2. {  
  3.     return *ptr * *ptr;  
  4. }  
int square(volatile int *ptr){    return *ptr * *ptr;}
 编译器将产生类似下面的代码:
[cpp] view plain copy
print?
  1. int square(volatile int *ptr)  
  2. {  
  3.     int a,b;  
  4.     a = *ptr;  
  5.     b = *ptr;  
  6.     return a * b;  
  7. }  
int square(volatile int *ptr){    int a,b;    a = *ptr;    b = *ptr;    return a * b;}
答案:由于*ptr的值可能被意想不到的改变,因此a和b可能是不同的。结果,这段代码可能返不是你所期望的平方值!正确的代码如下:
[cpp] view plain copy
print?
  1. long square(volatile int *ptr)  
  2. {  
  3.     int a;  
  4.     a =*ptr;  
  5.     return a * a;  
  6. }  
long square(volatile int *ptr){    int a;    a =*ptr;    return a * a;}
3、malloc(0)你注意过吗?下面分析这段代码:
[cpp] view plain copy
print?
  1. #include<stdio.h>  
  2. #include<stdlib.h>  
  3.   
  4. //malloc(0)函数 返回值不空  
  5.   
  6. int main(int argc, char **argv)  
  7. {  
  8.     char *pointer;  
  9.     if((pointer = (char *)malloc(0)) == NULL)  
  10.     {  
  11.         printf(”is null pointer\n”);  
  12.         printf(”pointer:%p\n”,pointer);  
  13.         *pointer = ’a’;  
  14.         printf(”%c\n”,*pointer);  
  15.         free(pointer);  
  16.     }  
  17.     else  
  18.     {  
  19.         printf(”is valited pointer\n”);  
  20.         printf(”pointer:%p\n”,pointer);  
  21.         *pointer = ’b’;  
  22.         printf(”%c\n”,*pointer);  
  23.         free(pointer);  
  24.     }  
  25.     return 0;  
  26. }  
#include<stdio.h>
#include<stdlib.h>//malloc(0)函数 返回值不空int main(int argc, char **argv){ char *pointer; if((pointer = (char *)malloc(0)) == NULL) { printf("is null pointer\n"); printf("pointer:%p\n",pointer); *pointer = 'a'; printf("%c\n",*pointer); free(pointer); } else { printf("is valited pointer\n"); printf("pointer:%p\n",pointer); *pointer = 'b'; printf("%c\n",*pointer); free(pointer); } return 0;}malloc(0)返回堆上的任意一个字节的地址,并且返回的地址空间可以对其进行操作。
运行结果:
is valited pointer
pointer:0x7f23adff
b
4、Typedef 在C语言中频繁用以声明一个已经存在的数据类型的同义字。也可以用预处理器做类似的事。例如,思考一下下面的例子,那个更好,为什么?
[cpp] view plain copy
print?
  1. #define dPS struct s *  
  2. typedef struct s * tPS;  
#define dPS struct s *typedef struct s * tPS;
答案是:typedef更好。思考下面的例子:
dPS p1,p2;
tPS p3,p4;
第一个扩展为
struct s * p1, p2;
上面的代码定义p1为一个指向结构的指,p2为一个实际的结构,这也许不是你想
要的。第二个例子正确地定义了p3 和p4 两个指针。

5、C语言同意一些令人震惊的结构,下面的结构是合法的吗,如果是它做些什么?
[cpp] view plain copy
print?
  1. int a = 5, b = 7, c;  
  2. c = a+++b;  
int a = 5, b = 7, c;c = a+++b;
上面的代码被处理成:
c = (a++)  +   b;
因此, 这段代码执行后的结果是 : a = 6, b = 7, c = 12。


原创粉丝点击