C语言面试题.docx
- 文档编号:28635023
- 上传时间:2023-07-19
- 格式:DOCX
- 页数:95
- 大小:68.32KB
C语言面试题.docx
《C语言面试题.docx》由会员分享,可在线阅读,更多相关《C语言面试题.docx(95页珍藏版)》请在冰豆网上搜索。
C语言面试题
1.编写my_strcpy函数,实现与库函数strcpy类似的功能,不能使用任何库函数;
答:
char*strcpy(char*strDest,constchar*strSrc)
{
if(strDest==NULL||strSrc==NULL)
returnNULL;
if(strDest==strSrc)
returnstrDest;
char*tempptr=strDest;
while((*strDest++=*strSrc++)!
=‘’);
returntempptr;
}
2.头文件中的ifndef/define/endif的作用?
答:
防止该头文件被重复引用。
3.#include与#include“file.h”的区别?
答:
前者编译器从标准库路径开始搜索file.h,而后者编译器从用户的工作路径开始搜索file.h。
4.在C++程序中调用被C编译器编译后的函数,为什么要加extern“C”?
答:
extern是C/C++语言中表明函数和全局变量作用范围(可见性)的关键字,其声明的函数和变量可以在本模块或其它模块中使用。
通常,在模块的头文件中对本模块提供给其它模块引用的函数和全局变量以关键字extern声明。
5.面向对象的三个基本特征,并简单叙述之?
答:
1)封装:
将客观事物抽象成类,每个类对自身的数据和方法实行protection(private,protected,public)
2)继承:
实现继承(指使用基类的属性和方法而无需额外编码的能力)、可视继承(子窗体使用父窗体的外观和实现代码)、接口继承(仅使用属性和方法,实现滞后到子类实现)。
3)多态:
允许将子类类型的指针赋值给父类类型的指针。
6.重载(overload)和重写(overried,有的书也叫做“覆盖”)的区别?
答:
从定义上来说:
重载:
是指允许存在多个同名函数,而这些函数的参数表不同(或许参数个数不同,或许参数类型不同,或许两者都不同)。
重写:
是指子类重新定义复类虚函数的方法。
从实现原理上来说:
重载:
编译器根据函数不同的参数表,对同名函数的名称做修饰,然后这些同名函数就成了不同的函数。
重写:
当子类重新定义了父类的虚函数后,父类指针根据赋给它的不同的子类指针,动态的调用属于子类的该函数,这样的函数调用在编译期间是无法确定的(调用的子类的虚函数的地址无法给出)。
7.多态的作用?
答:
主要是两个:
1)隐藏实现细节,使得代码能够模块化;扩展代码模块,实现代码重用;2)接口重用,为了类在继承和派生的时候,保证使用家族中任一类的实例的某一属性时的正确调用。
8.分别写出BOOL,int,float,指针类型的变量a与“零”的比较语句。
答:
BOOL:
if(!
a)orif(a)
int:
if(a==0)
float:
constEXPRESSIONEXP=0.000001
if(a
pointer:
if(a!
=NULL)orif(a==NULL)
9.请说出const与#define相比,有何优点?
答案:
1)const常量有数据类型,而宏常量没有数据类型。
编译器可以对前者进行类型安全检查。
而对后者只进行字符替换,没有类型安全检查,并且在字符替换可能会产生意料不到的错误。
2)有些集成化的调试工具可以对const常量进行调试,但是不能对宏常量进行调试。
10.简述数组与指针的区别?
数组要么在静态存储区被创建(如全局数组),要么在栈上被创建。
指针可以随时指向任意类型的内存块。
(1)修改内容上的差别
chara[]=“hello”;
a[0]=‘X’;
char*p=“world”;//注意p指向常量字符串
p[0]=‘X’;//编译器不能发现该错误,运行时错误
(2)用运算符sizeof可以计算出数组的容量(字节数)。
sizeof(p),p为指针得到的是一个指针变量的字节数,而不是p所指的内存容量。
C++/C语言没有办法知道指针所指的内存容量,除非在申请内存时记住它。
注意当数组作为函数的参数进行传递时,该数组自动退化为同类型的指针。
chara[]=“helloworld”;
char*p=a;
cout<
<计算数组和指针的内存容量 voidFunc(chara[100]) { cout< <} 11.变量的声明和定义有什么区别? 答: 声明变量不分配空间,定义变量要分配空间。 声明主要是告诉编译器,后面的引用都按声明的格式。 定义其实包含了声明的意思,同时要分配内存空间。 12.解释堆和栈的区别。 答: 堆(heap)——一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收。 注意它与数据结构中的堆是两回事,分配方式倒是类似于链表。 速度比较慢,而且容易产生内存碎片,不过用起来最方便。 栈(stack)——由编译器自动分配释放,存放函数的参数值,局部变量的值等。 其操作方式类似于数据结构中的栈。 由系统自动分配,速度较快。 但程序员是无法控制的。 13.const的作用是什么? 答: (1)可以定义const常量 (2)const可以修饰函数的参数、返回值,甚至函数的定义体。 被const修饰的东西都受到强制保护,可以预防意外的变动,能提高程序的健壮性。 14.下列哪两个是等同的 intb; Aconstint*a=&b;//指向常量的指针,不能通过指针改变b,但指针的地址可以改变。 Bconst*inta=&b;//指针的地址不可以改变,但可以通过指针改变b的值 Cconstint*consta=&b;//指针指向的值,和指针本身的地址都不能改变 Dintconst*consta=&b;//与c相同 15.完成程序,实现对数组的降序排序 #include voidsort(intarray[]); intmain() { intarray[]={45,56,76,234,1,34,23,2,3};//数字任//意给出 sort(array); return0; } voidsort(intarray[]) {____________________________________ inti,j,k; for(i=1;i<=7;i++){if(array[i]>array[i-1]) { k=ARRAY[i]; j=i-1; do { array[j+1]=array[j]; j–; } while(k>array[j]&&j>=0); array[j+1]=k; } } —————————————————– } 16.inti=(j=4,k=8,l=16,m=32);printf(“%d”,i);输出是多少? 答: 相当于i=j=4;i=k=8;i=l=16;i=m=32;故最后i=32; 17.请简述以下两个for循环的优缺点(5分) 1)for(i=0;i { if(condition) DoSomething(); else DoOtherthing(); } 2)if(condition) { for(i=0;i DoSomething(); } else { for(i=0;i0) { *psTo++=*psFrom++; } returnpvTo; } 19..C++里面如何声明constvoidf(void)函数为C程序中的库函数? 答: 在该函数前添加extern“C”声明。 由于编译后的名字不同,C++程序不能直接调用C函数。 20.请写出下面代码在32位平台上的运行结果,并说明sizeof的性质: #include #include intmain(void) { chara[30]; char*b=(char*)malloc(20*sizeof(char)); printf(“%d\n”,sizeof(a)); printf(“%d\n”,sizeof(b)); printf(“%d\n”,sizeof(a[3])); printf(“%d\n”,sizeof(b+3)); printf(“%d\n”,sizeof(*(b+4))); return0; } 答: 在32位系统下(如WIN32),指针长度为32位。 a是一个有30个元素的字符型数组;b是一个字符串指针;a[3]是字符型;b+3是指针;*(b+4)是字符型。 因此输出: 30、4、1、4、1 21.C++中,关键字struct和class的区别仅仅在于: struct定义的类的缺省成员为公有的,而class定义的类的缺省成员为私有的; 22.头文件的作用是什么? 答: 1)通过头文件来调用库功能。 2)头文件能加强类型安全检查。 23.C++函数中值的传递方式有哪几种? 答: C++函数的三种传递方式为: 值传递、指针传递和引用传递。 24.内存的分配方式的分配方式有几种? 答: 1)从静态存储区域分配。 内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。 例如全局变量。 2)在栈上创建。 在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。 栈内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。 3)从堆上分配,亦称动态内存分配。 程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时用free或delete释放内存。 动态内存的生存期由我们决定,使用非常灵活,但问题也最多。 25.设计函数intatoi(char*s)。 答: intatoi(char*s) { inti=0,sum=0,sign;//输入的数前面可能还有空格或制表符应加判断 while(*s==”||*s==’\t’) { i++; } sign=(*s==’-')? -1: 1; if(*s==’-'||*s==’+') { i++; } while(*s! =’\0′) { sum=*s-’0′+sum*10; i++; } returnsign*sum; } 26.编写strcat函数(6分) 已知strcat函数的原型是char*strcat(char*strDest,constchar*strSrc); 其中strDest是目的字符串,strSrc是源字符串。 (1)不调用C++/C的字符串库函数,请编写函数strcat 答: char*__cdeclstrcat(char*dst,constchar*src) { char*cp=dst; while(*cp) cp++;/*findendofdst*/ while(*cp++=*src++);/*Copysrctoendofdst*/ return(dst);/*returndst*/ } (2)strcat能把strSrc的内容连接到strDest,为什么还要char*类型的返回值? 答: 方便赋值给其他变量。 27.MFC中CString是类型安全类么? 答: 不是,其它数据类型转换到CString可以使用CString的成员函数Format来转换 28.函数模板与类模板有什么区别? 答: 函数模板的实例化是由编译程序在处理函数调用时自动完成的,而类模板的实例化必须由程序员在程序中显式地指定。 29.写一个“标准”宏MIN,这个宏输入两个参数并返回较小的一个。 答: #defineMIN(A,B)((A)<=(B)? (A): (B))宏的副作用(与某些函数的混淆): least=MIN(*p++,b)。 宏定义#defineMIN(A,B)((A)<=(B)? (A): (B))对MIN(*p++,b)的作用结果是: ((*p++)<=(b)? (*p++): (*p++)) 30.嵌入式系统中经常要用到无限循环,你怎么样用C编写死循环呢? 答: while (1){}或者for(;;) 31.用变量a给出下面的定义 a)一个整型数(Aninteger) b)一个指向整型数的指针(Apointertoaninteger) c)一个指向指针的的指针,它指向的指针是指向一个整型数(Apointertoapointertoaninteger) d)一个有10个整型数的数组(Anarrayof10integers) e)一个有10个指针的数组,该指针是指向一个整型数的(Anarrayof10pointerstointegers) f)一个指向有10个整型数数组的指针(Apointertoanarrayof10integers) g)一个指向函数的指针,该函数有一个整型参数并返回一个整型数(Apointertoafunctionthattakesanintegerasanargumentandreturnsaninteger) h)一个有10个指针的数组,该指针指向一个函数,该函数有一个整型参数并返回一个整型数(Anarrayoftenpointerstofunctionsthattakeanintegerargumentandreturnaninteger) 答案是: a)inta;//Aninteger b)int*a;//Apointertoaninteger c)int**a;//Apointertoapointertoaninteger d)inta[10];//Anarrayof10integers e)int*a[10];//Anarrayof10pointerstointegers f)int(*a)[10];//Apointertoanarrayof10integers g)int(*a)(int);//Apointertoafunctionathattakesanintegerargumentandreturnsaninteger h)int(*a[10])(int);//Anarrayof10pointerstofunctionsthattakeanintegerargumentandreturnaninteger 32.1)关键字static的作用是什么? 答: (1)用于全局变量; (2)用于局部变量;(3)用于函数。 2)关键字const有什么含意? 答: 表示常量不可以修改的变量。 33.如何判断一段程序是由C编译程序还是由C++编译程序编译的? 答案: #ifdef__cplusplus cout<<"c++"; #else cout<<"c"; #endif 34.数组a[N],存放了1至N-1个数,其中某个数重复一次。 写一个函数,找出被重复的数字.时间复杂度必须为o(N)函数原型: intdo_dup(inta[],intN) 答案: 如果数就是1-N-1,那么求出a[N]的和,然后减去1-N-1就行了。 (确定数字1-N) S=N*(N-1)/2; inti; ints=0; for(i=0;i { s+=a[i]; } intres=s–S; 35.程序由多个模块组成,所有模块都使用一组标准的包含文件和相同的编译选项。 在这种情况下,可以将所有包含文件预编译为一个预编译头。 char*constp; charconst*p constchar*p 上述三个有什么区别? 答: char*constp;//常量指针,p的值不可以修改 charconst*p;//指向常量的指针,指向的常量值不可以改 constchar*p;//和charconst*p 36.有1,2,….一直到n的无序数组,求排序算法,并且要求时间复杂度为O(n),空间复杂度O (1),使用交换,而且一次只能交换两个数。 #include intmain() { inta[]={10,6,9,5,2,8,4,7,1,3}; intlen=sizeof(a)/sizeof(int); inttemp; for(inti=0;i { temp=a[a[i]–1]; a[a[i]–1]=a[i]; a[i]=temp; if(a[i]==i+1) i++; } for(intj=0;j
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 试题
![提示](https://static.bdocx.com/images/bang_tan.gif)