资料库

C语言面试题大汇总之华为面试题.doc

第1页 / 共11页
第2页 / 共11页
第3页 / 共11页
第4页 / 共11页
第5页 / 共11页
第6页 / 共11页
第7页 / 共11页
第8页 / 共11页
资料共11页,剩余部分请下载后查看
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,120 7、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 个 字节. 所以它的大小是 20 data 是一个 struct, 每个变量分开占用空间. 依次为 int4 + DATE20 + double8 = 32. 所以结果是 20 + 32 = 52. 当然...在某些 16 位编辑器下, int 可能是 2 字节,那么结果是 int2 + DATE10 + double8 = 20 10、队列和栈有什么区别? 队列先进先出,栈后进先出 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=&inc; int temp =p(arg1); fun(&temp,&arg1, arg2); printf("%d\n",*arg2); main() { } int a; show(multi,10,&a); return 0; 答:110 12、请找出下面代码中的所以错误 说明:以下代码是把一个字符串倒序,如“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 = &src[len-1];//指向最后一个字符 while( len-- != 0 ) *d++=*s--; *d = 0;//尾部要加\0 printf("%s\n",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) 答案:63 2.用两个栈实现一个队列的功能?要求给出算法和思路! 设 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\n", str, l); return(0); 13.对于一个频繁使用的短小函数,在 C 语言中应用什么实现,在 C++中应用什么实现? c 用宏定义,c++用 inline 14.直接链接两个信令点的一组链路称作什么? 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= ;
分享到:
收藏