
华为面试笔试题目.doc
13页华为面试笔试题目华为面试笔试题目1、局部变量能否和全局变量重名答:能,局部会屏蔽全局要用全局变量,需要使用“::“局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内2、如何引用一个已经定义过的全局变量答:extern可以用引用头文件的方式,也可以用 extern 关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个变写错了,那么在编译期间会报错,如果你用 extern 方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错3、全局变量可不可以定义在可被多个.C 文件包含的头文件中 为什么答:可以,在不同的 C 文件中以 static 形式来声明同名全局变量可以在不同的 C 文件中声明同名的全局变量,前提是其中只能有一个 C 文件中对此变量赋初值,此时连接不会出错4、语句 for( ;1 ;)有什么问题 它是什么意思答:和 while(1)相同5、do……while 和 while……do 有什么区别答:前一个循环一遍再判断,后一个判断以后再循环6、请写出下列代码的输出内容以下是引用片段:#include main() { int a,b,c,d; a=10; b=a++; c=++a; d=10*a++; printf(“b,c,d:%d,%d,%d“,b,c,d); return 0; }答:10,12,1207、static 全局变量与普通的全局变量有什么区别 static 局部变量和普通局部变量有什么区别 static 函数与普通函数有什么区别全局变量(外部变量)的说明之前再冠以 static 就构成了静态的全局变量。
全局变量本身就是静态存储方式, 静态全局变量当然也是静态存储方式 这两者在存储方式上并无不同这两者的区别虽在于非静态全局变量的作用域是整个源程序, 当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的 而静态全局变量则限制了其作用域, 即只在定义该变量的源文件内有效, 在同一源程序的其它源文件中不能使用它由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用, 因此可以避免在其它源文件中引起错误从以上分析可以看出, 把局部变量改变为静态变量后是改变了它的存储方式即改变了它的生存期把全局变量改变为静态变量后是改变了它的作用域, 限制了它的使用范围static 函数与普通函数作用域不同仅在本文件只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义对于可在当前源文件以外使用的函数,应该在一个头文件中说明,要使用这些函数的源文件要包含这个头文件static 全局变量与普通的全局变量有什么区别:static 全局变量只初使化一次,防止在其他文件单元中被引用;static 局部变量和普通局部变量有什么区别:static 局部变量只被初始化一次,下一次依据上一次结果值;static 函数与普通函数有什么区别:static 函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝8、程序的局部变量存在于(堆栈)中,全局变量存在于(静态区 )中,动态申请数据存在于( 堆)中。
9、设有以下说明和定义:typedef union {long i; int k[5]; char c;} DATE;struct data { int cat; DATE cow; double dog;} too;DATE max;则语句 printf(“%d“,sizeof(struct date)+sizeof(max));的执行结果是:___52____答:DATE 是一个 union, 变量公用空间. 里面最大的变量类型是 int[5], 占用 20 个字节. 所以它的大小是 20data 是一个 struct, 每个变量分开占用空间. 依次为 int4 + DATE20 + double8 = 32.所以结果是 20 + 32 = 52.当然...在某些 16 位编辑器下, int 可能是 2 字节,那么结果是 int2 + DATE10 + double8 = 2010、队列和栈有什么区别队列先进先出,栈后进先出11、写出下列代码的输出内容以下是引用片段:#include int inc(int a) { return(++a); } int multi(int*a,int*b,int*c) { return(*c=*a**b); } typedef int(FUNC1)(int in); typedef int(FUNC2) (int*,int*,int*); void show(FUNC2 fun,int arg1, int*arg2) { INCp= int temp =p(arg1); fun( printf(“%d “,*arg2); } main() { int a; show(multi,10, return 0; }答:11012、请找出下面代码中的所有错误说明:以下代码是把一个字符串倒序,如“abcd”倒序后变为“dcba”以下是引用片段:1、#include“string.h“ 2、main() 3、{ 4、 char*src=“hello,world“; 5、 char* dest=NULL; 6、 int len=strlen(src); 7、 dest=(char*)malloc(len); 8、 char* d=dest; 9、 char* s=src[len]; 10、 while(len--!=0) 11、 d++=s--; 12、 printf(“%s“,dest); 13、 return 0; 14、}答:方法 1:以下是引用片段:int main() { char* src = “hello,world“; int len = strlen(src); char* dest = (char*)malloc(len+1);//要为\0 分配一个空间 char* d = dest; char* s = //指向最后一个字符 while( len-- != 0 ) *d++=*s--; *d = 0;//尾部要加\0 printf(“%s “,dest); free(dest);// 使用完,应当释放空间,以免造成内存汇泄露 return 0; }方法 2:以下是引用片段:#include #include main() { char str[]=“hello,world“; int len=strlen(str); char t; for(int i=0; i { t=str[i]; str[i]=str[len-i-1]; str[len-i-1]=t; } printf(“%s“,str); return 0; }1.-1,2,7,28,,126 请问 28 和 126 中间那个数是什么 为什么第一题的答案应该是 4^3-1=63规律是 n^3-1(当 n 为偶数 0,2,4)n^3+1(当 n 为奇数 1,3,5)答案:632.用两个栈实现一个队列的功能 要求给出算法和思路!设 2 个栈为 A,B, 一开始均为空.入队:将新元素 push 入栈 A;出队:(1)判断栈 B 是否为空;(2)如果不为空,则将栈 A 中所有元素依次 pop 出并 push 到栈B;(3)将栈 B 的栈顶元素 pop 出;这样实现的队列入队和出队的平摊复杂度都还是 O(1), 比上面的几种方法要好。
3.在 c 语言库函数中将一个字符转换成整型的函数是 atool()吗,这个函数的原型是什么函数名: atol功 能: 把字符串转换成长整型数用 法: long atol(const char *nptr);程序例:以下是引用片段:#include #include int main(void) { long l; char *str = “98765432“; l = atol(lstr); printf(“string = %s integer = %ld “, str, l); return(0); }13.对于一个频繁使用的短小函数,在 C 语言中应用什么实现,在 C++中应用什么实现c 用宏定义,c++用 inline14.直接链接两个信令点的一组链路称作什么PPP 点到点连接15.接入网用的是什么接口16.voip 都用了那些协议17.软件测试都有那些种类黑盒:针对系统功能的测试白合:测试函数功能,各函数接口18.确定模块的功能和模块的接口是在软件设计的那个队段完成的概要设计阶段19.enum string{x1,x2,x3=10,x4,x5,}x;问 x= 0x801005,0x8010f4 ;20.unsigned char *p1;unsigned long *p2;p1=(unsigned char *)0x801000;p2=(unsigned long *)0x810000;请问 p1+5= ;p2+5= ;选择题:21.Ethternet 链接到 Internet 用到以下那个协议A.HDLC;B.ARP;C.UDP;D.TCP;E.ID22.属于网络层协议的是:A.TCP;B.IP;C.ICMP;D.X.2523.Windows 消息调度机制是:A.指令队列;B.指令堆栈;C.消息队列;D.消息堆栈;24.unsigned short hash(unsigned short key){return (key>>)%256}请问 hash(16),hash(256)的值分别是:A.1.16;B.8.32;C.4.16;D.1.32找错题:25.请问下面程序有什么错误int a[60][250][1000],i,j,k;for(k=0;kMax_GT_Length) { return GT_Length_ERROR; } ....... }问答题:29.IP Phone 的原理是什么IPV630.TCP/IP 通信建立的过程怎样,端口有什么作用三次握手,确定是哪个应用程序使用该协议31.1 号信令和 7 号信令有什么区别,我国某前广泛使用的是那一种32.列举 5 种以上的新业务。
