华为C++笔试题及答案.docx

上传人:b****8 文档编号:9919644 上传时间:2023-02-07 格式:DOCX 页数:22 大小:24.47KB
下载 相关 举报
华为C++笔试题及答案.docx_第1页
第1页 / 共22页
华为C++笔试题及答案.docx_第2页
第2页 / 共22页
华为C++笔试题及答案.docx_第3页
第3页 / 共22页
华为C++笔试题及答案.docx_第4页
第4页 / 共22页
华为C++笔试题及答案.docx_第5页
第5页 / 共22页
点击查看更多>>
下载资源
资源描述

华为C++笔试题及答案.docx

《华为C++笔试题及答案.docx》由会员分享,可在线阅读,更多相关《华为C++笔试题及答案.docx(22页珍藏版)》请在冰豆网上搜索。

华为C++笔试题及答案.docx

华为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,而是得到最大的无符号整数,因此永远不会退出循环

答:

vectorarray(100);

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(dest);

constchar*psrc=static_cast(src);

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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 求职职场 > 简历

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1