C语言经典笔试题目
1.bool,float,指针变量 与 “零值” 比较的if语句
注意点:c语言中bool类型采用整数存储,0为false,非0均为true; float类型采用IEEE754标准,第一位符号位,中间8位阶数,最后23位为尾数(1.尾数),有精度问题。
bool flag 与零值比较:
标准答案:if(flag) if(!flag) ;
不良风格:if(flag == TRUE) if(flag ==1 ) if(flag == FALSE) if(flag == 0)
float f 与零值比较:
标准答案:
if( f < -0.000001 && f > 0.000001) // !=0
if( f > -0.000001 && f < 0.000001)// =0
错误写法:
if( f = 0 )
if( f = 0.0)
指针变量与零值比较:if(p == NULL) if(p != NULL)
2.数组int c[3][3]; 为什么c ,*c的值相等, (c+1), (*c+1)的值不等,c,*c,**c代表什么意思?
c是第一个元素的地址,*c是第一行元素的首地址,其实第一行元素的地址就是第一个元素的地址,**c是第一行一个元素。为什么c,*c的值相等?c:数组名;是一个二维指针,他的值就是数组的首地址,即第一行元素的首地址(等于*c),也等于第一行第一个元素的地址(&c[0][0]);可以说成是二维数组的行指针。
*c: 第一行元素的首地址;是一个一维指针,可以说成是二维数组的列指针。
**c:二维数组中的第一个元素的值;即:c[0][0]
所以:c和*c的值是相等的,但他们两者不能相互赋值(类型不同)
3.float a,b,c,问:等式(a+b)+c==(b+a)+c 和 (a+b)+c==(a+c)+b能否成立?
两者都不行。在比较float和double时,不能简单的比较。由于计算误差,相等的概率很低。应判断两数之间是否落在区间(-e,e)内。这个e应比浮点数的精度大一个数量级。
4.处理器标识#error的目的是什么?
主要考点:预处理指令。(预处理→编译→汇编→链接)
预处理指令在预处理阶段全部被替换,不带分号
参考答案:编译时输出一条错误信息,并中止继续编译。一般情况下和#if 一起使用
5.语句for( ; 1 ; )有什么问题?它是什么意思?
无限循环,等价于for(; ;) , while(1)
6.strcpy()和memcpy()的区别
字符串和内存的操作函数,都在string.h中,strcpy()在遇到‘\0‘就停止copy(包含‘\0‘),而memcpy()必须指定copy多少字节。
7.do...while 和 while...有什么区别?
前者至少执行一次,后者可能一次都不执行(直到型循环和当型循环)
8.怎样用C编写死循环
for(;;) while(1)
9.用变量a给出下面的定义
①一个有10个指针的数组,该指针是指向一个整型数的 // int* a[10]
②一个指向有10个整形数组的指针 // int (*a)[10]
③一个指向函数的指针,该函数有一个整形参数并返回整型值 // int (*a)(int)
④一个有10个指针的数组,该指针指向一个函数,该函数有一个整形参数并返回一个整形值 // int (*a[10])(int)
10.请问以下代码有什么问题:
char* s = "AAA"; printf("%s",s); s[0]=‘B‘; printf("%s",s);
考点:字符串常量问题。C语言中双引号部门内容称为字符串常量,其值不允许被更改。本题中,s指向了AAA,用s[0]试图更改常量值会出错。
若用char s[] = "AAA",再利用s[0]=‘B‘更改则不会报错
11.C和C++中struct有什么不同
c中的struct不可以含有成员函数,而c++中的struct可以;C++中struct和class的主要区别在于默认的存取权限不同,struct默认为public,而class默认为private
12.const 与 #define的比较 ,const有什么优点?
const常量有数据类型,而宏常量没有数据类型。编译器可以对前者进行类型安全检查,而对后者只进行字符替换,没有类型安全检查,并且在字符替换时可能产生意料不到的错误(边际效应)。
有些集成化的调试工具可以对const常量进行调试,但是不能对宏常量进行调试、
13.引用和指针的区别。
①引用被创建的同时必须被初始化,指针则可在任何时候被初始化
②不能有NULL引用,引用必须与合法的存储单元关联(指针则可以是NULL)
③一旦引用被初始化,就不能改变引用关系,指针则可以随时改变所指对象。
14.以下代码有什么问题?
void getmemory(char* p){ p = (char*)malloc(100); strcpy(p,"hello world"); } int main(){ char* str = NULL; getmemory(str); printf("%s\n",str); free(str); return 0; }
程序崩溃!getmemory中的malloc不能返回动态内存,free()对str操作很危险
15.以下代码产生什么结果?为什么?
char szstr[10]; strcpy(szstr,"123456789");
长度不一样 出现段错误,操作了不属于自己的空间
引申考点:"0123456789ABCDEF"[i] 这种写法也可以,得到指向第一个元素的地址值
16.数组和链表的区别
数组:数据顺序存储,固定大小;链表:数据可以随机存储,大小可动态改变
17.以下代码会出现什么问题?打印结果是多少?
void main(){ char aa[10]; printf("%d",strlen(aa)); }//输出结果在不同编译器下结果会不一样
sizeof()返回值和是否初始化无关,但strlen()返回值与是否初始化有关,打印结果未知。
18.给定结构struct A,问sizeof(A)=?
struct A{ char t:4; char k:4; unsigned short i:8; unsigned long m; };
答案 : 8 (考虑字节对齐)
19.给定结构struct name1,问sizeof(name1)=?
struct name1{ char str; short x; int num; };
答案:8
20.int a,b,c 请写函数实现c = a+b,不可以改变数据类型,如将c改为long int,判断是否溢出?
bool add(int a,int b,int* c){ *c = a+b; return (a>0 && b>0 && (*c < a || *c < b) || (a<0 && b<0 && (*c > a) || *c >b))); }