整理华为C++笔试题及答案.docx
- 文档编号:7910424
- 上传时间:2023-01-27
- 格式:DOCX
- 页数:19
- 大小:25.16KB
整理华为C++笔试题及答案.docx
《整理华为C++笔试题及答案.docx》由会员分享,可在线阅读,更多相关《整理华为C++笔试题及答案.docx(19页珍藏版)》请在冰豆网上搜索。
整理华为C++笔试题及答案
1.static有什么用途?
(请至少说明两种)
1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。
2)在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。
它是一个本地的全局变量。
3)在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。
那就是,这个函数被限制在声明它的模块的本地范围内使用
2.引用与指针有什么区别?
1)引用必须被初始化,指针不必。
2)引用初始化以后不能被改变,指针可以改变所指的对象。
3)不存在指向空值的引用,但是存在指向空值的指针。
3.描述实时系统的基本特性
在特定时间内完成特定的任务,实时性与可靠性。
4.全局变量和局部变量在内存中是否有区别?
如果有,是什么区别?
全局变量储存在静态数据库,局部变量在堆栈。
5.什么是平衡二叉树?
左右子树都是平衡二叉树且左右子树的深度差值的绝对值不大于1。
6.堆栈溢出一般是由什么原因导致的?
没有回收垃圾资源。
7.什么函数不能声明为虚函数?
constructor函数不能声明为虚函数。
8.冒泡排序算法的时间复杂度是什么?
时间复杂度是O(n^2)。
9.写出floatx与“零值”比较的if语句。
if(x>0.000001&&x<-0.000001)
10.Internet采用哪种网络协议?
该协议的主要层次结构?
Tcp/Ip协议
主要层次结构为:
应用层/传输层/网络层/数据链路层/物理层。
11.Internet物理地址和IP地址转换采用什么协议?
ARP(AddressResolutionProtocol)(地址解析協議)
12.IP地址的编码分为哪俩部分?
IP地址由两部分组成,网络号和主机号。
不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。
13.用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。
写出C程序。
循环链表,用取余操作做
14.不能做switch()的参数类型是:
switch的参数不能为实型。
1.以下三条输出语句分别输出什么?
[C易]
charstr1[]="abc";
charstr2[]="abc";
constcharstr3[]="abc";
constcharstr4[]="abc";
constchar*str5="abc";
constchar*str6="abc";
cout< 0 cout< 0 cout< 1 2.非C++内建型别A和B,在哪几种情况下B能隐式转化为A? [C++中等] 答: a.classB: publicA{……}//B公有继承自A,可以是间接继承的 b.classB{operatorA();}//B实现了隐式转化为A的转化 c.classA{A(constB&);}//A实现了non-explicit的参数为B(可以有其他带默认值的参数)构造函数 d.A&operator=(constA&);//赋值操作,虽不是正宗的隐式类型转换,但也可以勉强算一个 3.以下代码中的两个sizeof用法有问题吗? [C易] voidUpperCase(charstr[])//将str中的小写字母转换成大写字母 { for(size_ti=0;i if('a'<=str[i]&&str[i]<='z') str[i]-=('a'-'A'); } charstr[]="aBcDe"; cout<<"str字符长度为: "< UpperCase(str); cout< 答: str作为参数传递后,在UpperCase中sizeof(str)=1; 4.以下代码有什么问题? [C难] voidchar2Hex(charc)//将字符以16进制表示 { charch=c/0x10+'0';if(ch>'9')ch+=('A'-'9'-1); charcl=c%0x10+'0';if(cl>'9')cl+=('A'-'9'-1); cout< } charstr[]="Ilove中国"; for(size_ti=0;i char2Hex(str[i]); cout< 5.以下代码有什么问题? [C++易] structTest { Test(int){} Test(){} voidfun(){} }; voidmain(void) { Testa (1); a.fun(); Testb();答: Testb; b.fun(); } 6.以下代码有什么问题? [C++易] cout<<(true? 1: "1")< 7.以下代码能够编译通过吗,为什么? [C++易] unsignedintconstsize1=2; charstr1[size1]; unsignedinttemp=0; cin>>temp; unsignedintconstsize2=temp; charstr2[size2]; 答: 不能用变量给const常量赋值 8.以下代码中的输出语句输出0吗,为什么? [C++易] structCLS { intm_i; CLS(intI): m_i(i){} CLS() { CLS(0);答: 在CLS()中CLS(0)创建了另一个对象,所以并没有对obj对象进行赋值,而是其他对象赋值。 } }; CLSobj; cout< 不能,因为m_i没有初始化,会付一个很大的数, 9.C++中的空类,默认产生哪些类成员函数? [C++易] 答: classEmpty { public: Empty();//缺省构造函数 Empty(constEmpty&);//拷贝构造函数 ~Empty();//析构函数 Empty&operator=(constEmpty&);//赋值运算符 Empty*operator&();//取址运算符 constEmpty*operator&()const;//取址运算符const }; 10.以下两条输出语句分别输出什么? [C++难] floata=1.0f; cout<<(int)a< cout<<(int&)a< cout< Floatb=0.0f; cout<<(int)b< cout<<(int&)b< cout< 11.以下反向遍历array数组的方法有什么错误? [STL易] vectorarray;(vector没有给定具体类型也没有说明是模板类型)size_type是无符号整数,当j=0时,做减1操作不会得到-1,而是得到最大的无符号整数,因此永远不会退出循环 答: vector array.push_back (1); array.push_back (2); array.push_back(3); for(vector: : size_typei=array.size()-1;i>=0;--i)//反向遍历array数组 { cout< } 12.以下代码有什么问题? [STL易] typedefvector IntArray; IntArray array; array.push_back (1); array.push_back (2); array.push_back (2); array.push_back(3); //删除array数组中所有的2 for(IntArray: : iteratoritor=array.begin();itor! =array.end();++itor) { if(2==*itor)array.erase(itor); } 其实这里面隐藏着一个很严重的错误: 当veci.erase(iter)之后,iter就变成了一个野指针,对一个野指针进行iter++是肯定会出错的。 13.写一个函数,完成内存之间的拷贝。 [考虑问题是否全面] 答: void*mymemcpy(void*dest,constvoid*src,size_tcount) { char*pdest=static_cast constchar*psrc=static_cast if(pdest>psrc&&pdest { for(size_ti=count-1;i! =-1;--I) pdest[i]=psrc[i]; } else { for(size_ti=0;i pdest[i]=psrc[i]; } returndest; } intmain(void) { charstr[]="0123456789"; mymemcpy(str+1,str+0,9); cout< system("Pause"); return0; } 本试题仅用于考查C++/C程序员的基本编程技能。 内容限于C++/C常用语法,不涉及数据结构、算法以及深奥的语法。 考试成绩能反映出考生的编程质量以及对C++/C的理解程度,但不能反映考生的智力和软件开发能力。 笔试时间90分钟。 请考生认真答题,切勿轻视。 一、请填写BOOL,float,指针变量与“零值”比较的if语句。 (10分) 提示: 这里“零值”可以是0,0.0,FALSE或者“空指针”。 例如int变量n与“零值”比较的if语句为: if(n==0) if(n! =0) 以此类推。 请写出BOOLflag与“零值”比较的if语句: 请写出floatx与“零值”比较的if语句: 浮点数是不可以直接比较大小的,因为是非精确存储,只能设置一个精度,然后在允许误差内的就认为是相等的;对浮点型数比较的时候用==是不对的 请写出char*p与“零值”比较的if语句: 二、以下为WindowsNT下的32位C++程序,请计算sizeof的值(10分) charstr[]=“Hello”;6 char*p=str;4 intn=10;4 请计算 sizeof(str)= sizeof(p)= sizeof(n)= voidFunc(charstr[100]) { 请计算 sizeof(str)=4 } void*p=malloc(100); 请计算 sizeof(p)=4 三、简答题(25分) 1、头文件中的ifndef/define/endif干什么用? 有两个C文件,这两个C文件都include了同一个头文件。 而编译时,这两个C文件要一同编译成一个可运行文件,于是问题来了,大量的声明冲突。 使用这个就不会造成重复定义。 2.在#ifndef中定义变量出现的问题(一般不定义在#ifndef中)。 #ifndefAAA #defineAAA ... inti; ... #endif 里面有一个变量定义 在vc中链接时就出现了i重复定义的错误,而在c中成功编译。 结论: (1).当你第一个使用这个头的.cpp文件生成.obj的时候,inti在里面定义了当另外一个使用这个的.cpp再次[单独]生成.obj的时候,inti又被定义然后两个obj被另外一个.cpp也include这个头的,连接在一起,就会出现重复定义. (2).把源程序文件扩展名改成.c后,VC按照C语言的语法对源程序进行编译,而不是C++。 在C语言中,若是遇到多个inti,则自动认为其中一个是定义,其他的是声明。 (3).C语言和C++语言连接结果不同,可能(猜测)时在进行编译的时候,C++语言将全局 变量默认为强符号,所以连接出错。 C语言则依照是否初始化进行强弱的判断的。 (参考) .h中只声明externinti;在.cpp中定义 注意问题: (1).变量一般不要定义在.h文件中。 2、#include和#include“filename.h”有什么区别? 3、const有什么用途? (请至少说明两种) 类型修饰符: 定义常量,类型检查,保护被修饰符不被修改,const定义的常量在程序运行过程中只有一份拷贝,而#define定义的常量在内存中有若干个拷贝,#define给出的是立即数,#define定义的常量在内存中有若干个拷贝。 4、在C++程序中调用被C编译器编译后的函数,为什么要加extern“C”声明? 函数经过编译系统的翻译成汇编,函数名对应着汇编标号。 因为C编译函数名与得到的汇编代号基本一样,如: fun()=>_fun,main=>_main但是C++中函数名与得到的汇编代号有比较大的差别。 如: 由于函数重载,函数名一样,但汇编代号绝对不能一样。 为了区分,编译器会把函数名和参数类型合在一起作为汇编代号, 这样就解决了重载问题。 具体如何把函数名和参数类型合在一起,要看编译器的帮助说明了。 这样一来,如果C++调用C,如fun(),则调用名就不是C的翻译结果_fun,而是带有参数信息的一个名字,因此就不能调用到fun(),为了解决这个问题,加上extern"C"表示该函数的调用规则是C的规则,则调用时就不使用C++规则的带有参数信息的名字,而是_fun,从而达到调用C函数的目的。 5、请简述以下两个for循环的优缺点 //第一个 for(i=0;i++;) { if(condition) DoSomething(); else DoOtherthing();} //优点: 缺点 第二个 if(condition){ for(i=0;i++;) DoSomething(); }else { for(i=0;i++;) DoOtherthing(); } : 优点: 缺点: 四、有关内存的思考题(20分) voidGetMemory(char*p) { p=(char*)malloc(100);//没有free的操作肯定会造成内存泄漏 } voidTest(void) { char*str=NULL; GetMemory(str); strcpy(str,"helloworld"); printf(str); } 请问运行Test函数会有什么样的结果? 答: char*GetMemory(void) { charp[]="helloworld";//存储在stack中,但是stack中的变量在完成function之后会自动释放,所以也会返回一个野指针 returnp; } voidTest(void) { char*str=NULL; str=GetMemory(); printf(str); } 请问运行Test函数会有什么样的结果? 答: VoidGetMemory2(char**p,intnum) { *p=(char*)malloc(num); } voidTest(void) { char*str=NULL; GetMemory(&str,100); strcpy(str,"hello"); printf(str); } 请问运行Test函数会有什么样的结果? 答: voidTest(void) { char*str=(char*)malloc(100); strcpy(str,“hello”); free(str); if(str! =NULL) { strcpy(str,“world”); printf(str); } } 请问运行Test函数会有什么样的结果? world 答: 五、编写strcpy函数(10分) 已知strcpy函数的原型是: char*strcpy(char*strDest,constchar*strSrc) 其中strDest是目的字符串,strSrc是源字符串。 (1)不调用C++/C的字符串库函数,请编写函数strcpy (2)strcpy能把strSrc的内容复制到strDest,为什么还要char*类型的返回值? 为了实现链式表达式。 char*strcpy(char*strDest,constchar*strSrc) { assert((strDest! =NULL)&&(strSrc! =NULL)); char*address=strDest; while((*strDest++=*strSrc++)! =‘\0’); returnaddress; } 从函数中返回函数体内分配的内存是十分危险的做法,他把释放内存的义务抛给不知情的调用者,绝大多数情况下,调用者不会释放内存,这导致内存泄漏。 六、编写类String的构造函数、析构函数和赋值函数(25分) 已知类String的原型为: classString { public: String(constchar*str=NULL);//普通构造函数 String(constString&other);//拷贝构造函数 ~String(void);//析构函数 String&operate=(constString&other);//赋值函数 private: char*m_data;//用于保存字符串 }; 请编写String的上述4个函数。 附录C: C++/C试题的答案与评分标准 一、请填写BOOL,float,指针变量与“零值”比较的if语句。 (10分) 请写出BOOLflag与“零值”比较的if语句。 (3分) 标准答案: if(flag) if(! flag) constfloatEPSINON=0.00001; if((x>=-EPSINON)&&(x<=EPSINON) if(p==NULL) if(p! =NULL) 二、以下为WindowsNT下的32位C++程序,请计算sizeof的值(10分) charstr[]=“Hello”; char*p=str; intn=10; 请计算 sizeof(str)=6(2分) sizeof(p)=4(2分) sizeof(n)=4(2分) voidFunc(charstr[100]) { 请计算 sizeof(str)=4(2分) } void*p=malloc(100); 请计算 sizeof(p)=4(2分) 三、简答题(25分) 1、头文件中的ifndef/define/endif干什么用? (5分) 答: 防止该头文件被重复引用。 2、#include和#include“filename.h”有什么区别? (5分) 华为的C\C++面试题 Q1: 请你分别划划OSI的七层网络结构图,和TCP/IP的五层结构图? OSI: 物理层,数据链路层,网络层,传输层,会话层,表示层,应用层; TCP: 物理层,网络接口层,互联网层,传输层,应用层; 应用层FTPSMTPHTTP... 传输层TCPUDP 网络层IPICMPARP 链路层以太网令牌环FDDI... : Q2: 请你详细的解释一下IP协议的定义,在哪个层上面,主要有什么作用? : TCP与UDP呢? IP协议是网络层, : 总得来说前面两道题目还是比较简单的! : Q3: 请问交换机和路由器分别的实现原理是什么? 分别在哪个层次上面实 : 现的? : Q4: 请问C++的类和C里面的struct有什么区别? : Q5: 请讲一讲析构函数和虚函数的用法和作用? : Q6: 全局变量和局部变量有什么区别? 实怎么实现的? 操作系统和编译器 : 是怎么知道的? : Q7: 一些寄存器的题目,我忘记了具体实什么题目,主要好像是寻址和内 : 存管理等一些知识,不记得了。 : Q8: 8086是多少尉的系统? 在数据总线上是怎么实现的? 还有一些硬件方 : 面的知识我既不清楚了。 : 一般建议参加华为的研发面试的同学先要准备一下相关的知识,软件的主要 : 是看看C和数据结构方面的,硬件模电,数电和微机原理 两道c面试题 1、一个学生的信息是: 姓名,学号,性别,年龄等信息,用一个链表,把这些学生信息连在一起,给出一个age,在些链表中删除学生年龄等于age的学生信息。 程序代码 #Include"stdio.h" #Include"conio.h" structstu{ charname[20]; charsex; intno; intage; struc
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 整理 华为 C+ 笔试 答案