2020年度华为软件研发面试题.pdf
《2020年度华为软件研发面试题.pdf》由会员分享,可在线阅读,更多相关《2020年度华为软件研发面试题.pdf(132页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、2020年度华为软件研发面试题文档仅供参考,不当之处,请联系改正。华为软件研发面试题21、局部变量能否和全局变量重名?答:能,局部会屏蔽全局。要用全局变量,需要使用七:;局部变量能够与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内能够定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。2、如何引用一个已经定义过的全局变量?答:extern 能够用引用头文件的方式,也能够 用 extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个编写错了,
2、那么在编译期间会报错,如果你用 extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。3、全局变量可不能够定义在可被多个.C文件包含的头文件中?为什么?文档仅供参考,不当之处,请联系改正。答:能够,在不同的C 文件中以static形式来声明同名全局变量。能够在不同的C 文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错.4、请写出下列代码的输出内容#include int main(void)(int a,b,c,d;a=10;b=a+;c=+a;d=10*a+;printf(nb,c,d:%d,%d,%dn,b,c,d);
3、return 0;)答:10,12,1205、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?文档仅供参考,不当之处,请联系改正。答:1)全局变量(外部变量)的说明之前再冠以static就构成了静态的全局变量。全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。这两者在存储方式上并无不同。这两者的区别在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。而静态全局变量则限制了其作用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文件
4、中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此能够避免在其它源文件中引起错误。2)从以上分析能够看出,把局部变量改变为静态变量后是改变了它的存储方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它 的 作 用 域,限 制 了 它 的 使 用 范 围。3)static函数与普通函数作用域不同,仅在本文件。只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义。对于可在当前源文件以外使用的函数,应该在一个头文件中说明,要使用这些函数文档仅供参考,不当之处,请联系改正。的源文件要包含这个头文件综上所述:s
5、tatic全局变量与普通的全局变量有什么区别:static全局变量只初使化一次,防止在其它文件单元中被引用;static局部变量和普通局部变量有什么区别:static局部变量只被初始化一次,下一次依据上一次结果值;static函数与普通函数有什么区别:static函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝6、程序的局部变量存在于(堆栈)中,全局变量存在于(静 态 区)中,动态申请数据存在于(堆)中。7、设有以下说明和定义:typedef union(long i;int k5;char c;DATE;文档仅供参考,不当之处,请联系改正。struct dataint cat;DAT
6、E cow;doub le dog;too;DATE max;则 语 句 printf(n%dn,sizeof(structdata)+sizeof(max);的执行结果是:52考点:区别struct与union.(一般假定在32位机器上)答:DATE是一个im ion,变量公用空间.里面最大的变量类型是int5,占用20个字节.因此它的大小是20.data是一个struct,每个变量分开占用空间.依次为int4+DATE20+doub le8=3 2.因此结果是20+3 2=5 2.当然 在某些16位编辑器下,int可能是2字节,那么结果是int2+DATE10+doub les=208、队
7、列和栈有什么区别?队列先进先出,栈后进先出9、写出下列代码的输出内容文档仅供参考,不当之处,请联系改正。#include int inc(int a)return(+a);int multi(int*a,mt*b,int*c)return(*c=*a*b);typedef int(FUNCl)(int in);typedef int(FUNC2)(int*,int*,mt*);void show(FUNC2 fun,int argl,int*arg2)(FUNCI p=&inc;int temp=p(argl);fun(&temp,&argl,arg2);printf(n%dnn,*arg2)
8、;)main()(int a;局部变量a 为 0;show(multi,10,&a);return 0;)答:110文档仅供参考,不当之处,请联系改正。10、请找出下面代码中的所有错误(题目不错,值得一看)说明:以下代码是把一个字符串倒序,如“ab ed”倒序后变为“deb a”#include nstring.hmain()(char*src=nhello,worldn;char*dest=NULL;int len=strlen(src);dest=(char*)malloc(leii);char*d=dest;char*s=srclen;while(len!=0)d+=s;printf(n
9、%sn,dest);return 0;)答:方法1:一共有4 个错误;int main()文档仅供参考,不当之处,请联系改正。char*src=hello,world;int len=strlen(src);char*dest=(char*)maHoc(len+l);要为分配一个空间 char*d=dest;char*s=&srcIen-l;指向最后一个字符while(len !=0)*d+=*s;*d=0;尾部要加0printf(n%snn,dest);free(dest);/使用完,应当释放空间,以免造成内存汇泄露dest=NULL;防止产生野指针return 0;)方法2:(方法一需要额
10、外的存储空间,效率不高.)不错的想法#include#include main()char str=nhello,worldn;文档仅供参考,不当之处,请联系改正。int len=strlen(str);char t;for(int i=0;ilen/2;i+)(t=stri;stri=strlen-i-l;小心一点strlen-i-l=t;)printf(n%sn,str);return 0;)IL对于一个频繁使用的短小函数,在 C 语言中应用什么实现,在 C+中应用什么实现?c 用宏定义,C+用 inline12.直接链接两个信令点的一组链路称作什么?PPP点到点连接13.接入网用的是什么
11、接口?V5接口14.voip都用了那些协议?H.323协议簇、SIP协议、Skype协议、H.248和 MGCP协议15.软件测试都有那些种类?文档仅供参考,不当之处,请联系改正。黑盒:针对系统功能的测试白盒:测试函数功能,各函数接口16.确定模块的功能和模块的接口是在软件设计的那个队段完成的?概要设计阶段17.unsigned char*pl;unsigned long*p2;pl=(unsigned char*)0 x801000;p2=(unsigned long*)0 x810000;请问p l+5=;p 2+5=;答案:0 x801005(相当于加上5 位)0 x810014(相当于
12、加上20位);选择题:21.Ethternet链接到Internet用到以下那个协议?DA.HDLC;B.ARP;C.UDP;D.TCP;E.ID22.属于网络层协议的是:(BC)A.TCP;B.IP;C.ICMP;D.X.25文档仅供参考,不当之处,请联系改正。23.Windows消息调度机制是:(C)A.指令队列;B.指令堆栈;C.消息队列;D.消息堆栈;找错题:25.请问下面程序有什么错误?int a602501000,i,j,k;for(k=0;kMax_GT_Length)return GT_Length_ERROR;)答:死循环问答题:29.IP Phone的原理是什么?IP 电话
13、(又称IP PHONE或 VoIP)是建立在IP技术上的分组化、数字化传输技术,其基本原理是:经过语音压缩算法对语音数据进行压缩编码处理,然后把这些语音数据按IP等相关协议进行打包,经 过 I P 网络把数据包传输到接收地,再把这些语音数据包串起来,经过解码解压处理后,恢复成原来的语音信号,从而达到由IP 网络传送语音的目的。30.TCP/IP通信建立的过程怎样,端口有什么作文档仅供参考,不当之处,请联系改正。用?三次握手,确定是哪个应用程序使用该协议31.1号信令和7号信令有什么区别,中国某前广泛使用的是那一种?1号信令接续慢,可是稳定,可靠。7号信令的特点是:信令速度快,具有提供大量信令的
14、潜力,具有改变和增加信令的灵活性,便于开放新业务,在通话时能够随意处理信令,成本低。当前得到广泛应用。32.列举5种以上的电话新业务如“闹钟服务”、“免干扰服务”、“热线服务”、“转移呼叫”、“遇忙回叫”、“缺席用户服务”、“追查恶意呼叫”、“三方通话”、“会议电话”、“呼出限制”、“来电显示”、“虚拟网电话”等四.找错题:1.请问下面程序有什么错误?int a602501000,i,j,k;for(k=0;k=1000;k+)fora=0;j250;j+)for(i=0;i60;i+)aiUk=O;答:把循环语句内外换一下文档仅供参考,不当之处,请联系改正。2.#define Max_CB
15、500void LmiQueryCSmd(Struct MSgCB*pmsg)(unsigned char ucCmdNum;for(ucCmdNum=0;ucCmdNumMax_CB;ucCmdNum+)答:死循环,unsigned int的取值范围是0-2553.以下是求一个数的平方的程序,请找出错误:#define SQUARE(a)(a)*(a)int a=5;int b;b=SQUARE(a+);答:结果与编译器相关,得到的可能不是平方值.微软亚洲技术中心的面试题!1.进程和线程的差别。答:线程是指进程内的一个执行单元,也是进程内的可调度实体.文档仅供参考,不当之处,请联系改正。与进
16、程的区别:调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位并发性:不但进程之间能够并发执行,同一个进程的多个线程之间也可并发执行拥有资源:进程是拥有资源的一个独立单位,线程不拥有系统资源,但能够访问隶属于进程的资源.(4)系统开销:在创立或撤消进程时,由于系统都要为之分配和回收资源,导致系统的开销明显大于创立或撤消线程时的开销。2.测试方法答:人工测试:个人复查、抽查和会审机器测试:黑盒测试和白盒测试3.Heap与 stack的差别。答:Heap是堆,stack是栈。Stack的空间由操作系统自动分配/释放,Heap上的空间手动分配/释放。Stack空间有限,Heap是很大的自由
17、存储区C 中 的 m alloc函数分配的内存空间即在堆上,C+中对应的是new操作符。程序在编译期对变量和函数分配内存都在栈上文档仅供参考,不当之处,请联系改正。进行,且程序运行过程中函数调用时参数的传递也在栈上进行4.Windows下的内存是如何管理的?分页管理8.谈谈IA32下的分页机制小页(4K)两级分页模式,大页(4M)一级9.给两个变量,如何找出一个带环单链表中是什么地方出现环的?一个递增一,一个递增二,她们指向同一个接点时就是环出现的地方10.在IA32中一共有多少种办法从用户态跳到内核态?经过调用门,从ring3到ring。,中断从ring3到ringO,进入vm86等等11.
18、如果只想让程序有一个实例运行,不能运行两个。像winamp一样,只能开一个窗口,怎样实现?用内存映射或全局原子(互斥变量)、查找窗口句柄.FindWindow,互斥,写标志到文件或注册表,共享内存。.文档仅供参考,不当之处,请联系改正。12.如何截取键盘的响应,让所有的或变成,b,?答:键盘钩子 SetWindowsHookEx14.存储过程是什么?有什么用?有什么优点?答:我的理解就是一堆sql的集合,能够建立非常复杂的查询,编译运行,因此运行一次后,以后再运行速度比单独执行SQL快很多15.Template有什么特点?什么时候用?答:Template能够独立于任何特定的类型编写代码,是泛型
19、编程的基础.当我们编写的类和函数能够多态的用于跨越编译时不相关的类型时用Template.模板主要用于STL中的容器,算法,迭代器等以及模板元编程.(C+的 template是实现在库设计和嵌入式设计中的关键。template能实现抽象和效率的结合;同时template还能有效地防止代码膨胀)16.谈谈Windows DNA结构的特点和优点。答:Windows Distrib uted interNet ApplicationArchitecture(Windows分布式应用结构,简称Windows DNA)是微软创立新一代高适应性商文档仅供参考,不当之处,请联系改正。业解决方案的框架,它使公
20、司能够充分地挖掘数字神经系统的优点。Windows DNA是第一个将Internet、客户/服务器、和用于计算的PC 模型结合并集成在一起的为新一类分布式计算方案而设计的应用软件体系结构1 7.网络编程中设计并发服务器,使用多进程与多线程,请问有什么区别?答:1)进程:子进程是父进程的复制品。子进程获得父进程数据空间、堆和栈的复制品。2)线程:相对与进程而言,线程是一个更加接近与执行体的概念,它能够与同进程的其它线程共享数据,但拥有自己的栈空间,拥有独立的执行序列。两者都能够提高程序的并发度,提高程序运行效率和响应时间。线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源管理和保护;而进
21、程正相反。同时,线程适合于在SMP机器上运行,而进程则能够跨机器迁移。思科1.用宏定义写出swap(x,y)#define swap(x,y)文档仅供参考,不当之处,请联系改正。x=x+y;y=x-y;x=x-y;2.数组aN,存放了 1至N1个数,其中某个数重复一次。写一个函数,找出被重复的数字.时间复杂度必须为。(N)函数原型:int do_dup(int a,int N)答:int do_dup(int a,int N)(int temp;a0为监视哨while(aO!=aaO)(temp=a0;a0=atemp;atemp=temp;)return a0;/b y X-Forever,
22、1030示例:文档仅供参考,不当之处,请联系改正。#include#include#define SIZE 30/*数组大小 刃#define NUM 5/*每行打印个数*/void init(iiit*a,int n);void print(int*a,int n,int num);int do_dup(int a,int N);/*函数原型int main(void)(int arrSIZE;init(arr,SIZE);print(arr,SIZE,NUM);printf(nnthe repeat numdo_dup(arr,SIZE);/*print(arr,SIZE,NUM);*/*
23、/is:%dnn,printf(nnn);文档仅供参考,不当之处,请联系改正。system(npausen);return 0;)void init(int*a,int N)/*初始化随机数组arrSIZE切(int i;int pos;/*初始化所有数组元素为0*/for(i=0;i ai=0;)/*随机初始化1-N-l*/for(i=l;i pos=rand()%N;while(apos%N)+pos;)文档仅供参考,不当之处,请联系改正。apos%N=i;)/*随机设置重复元素*/for(i=0;ai;+i)()ai=rand()%(N-1)+1;)int do_dup(int a,in
24、t N)(int temp;a0为监视哨while(a0!=aa0)(temp=a0;a0=atemp;atemp=temp;)return a0;文档仅供参考,不当之处,请联系改正。)/*分行打印数组元素*/void print(int*a,int n,int num)(int i;for(i=0;i printf(n%5dM,*(a+i);+i;if(i%num=0)(printf(Hnn);)3 一语句实现x是否为2的若干次嘉的判断答:方法 l)int i=512;cout b oolalpha (i&(i-1)?false:true)endl;位与为0,则表示是2的若干次嘉2)retu
25、rn(xN=l);文档仅供参考,不当之处,请联系改正。4.unsigned int intvert(unsigned int x,int p,int n)实现对x 的进行转换,p为起始转化位,n为需要转换的长度,假 设 起 始 点 在 右 边.如 x=0b 00010001,p=4,n=3 转换后 x=0b 0110 0001答unsigned int intvert(unsigned int x,int p,int n)假定 p=4,n=3(unsigned int _t=0;unsigned int _a=1;for(int i=0;i n;+i)循环的目的主要是(_t|=_a;位或_a=
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2020 年度 华为 软件 研发 试题
限制150内