《华为C++笔试题及答案.doc》由会员分享,可在线阅读,更多相关《华为C++笔试题及答案.doc(12页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。
1、【精品文档】如有侵权,请联系网站删除,仅供学习与交流华为C+笔试题及答案.精品文档.1.static有什么用途?(请至少说明两种) 1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。 2) 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。 3) 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范围内使用2.引用与指针有什么区别? 1) 引用必须被初始化,指针不必。 2) 引用初始化以后不能被改变,指针可以改变所指的对象。 3) 不存在指向
2、空值的引用,但是存在指向空值的指针。3.描述实时系统的基本特性 在特定时间内完成特定的任务,实时性与可靠性。4.全局变量和局部变量在内存中是否有区别?如果有,是什么区别? 全局变量储存在静态数据库,局部变量在堆栈。5.什么是平衡二叉树? 左右子树都是平衡二叉树 且左右子树的深度差值的绝对值不大于1。6.堆栈溢出一般是由什么原因导致的? 没有回收垃圾资源。7.什么函数不能声明为虚函数? constructor函数不能声明为虚函数。8.冒泡排序算法的时间复杂度是什么? 时间复杂度是O(n2)。9.写出float x 与“零值”比较的if语句。 if(x0.000001&x-0.000001)10.
3、Internet采用哪种网络协议?该协议的主要层次结构? Tcp/Ip协议 主要层次结构为: 应用层/传输层/网络层/数据链路层/物理层。11.Internet物理地址和IP地址转换采用什么协议? ARP (Address Resolution Protocol)(地址解析協議)12.IP地址的编码分为哪俩部分? IP地址由两部分组成,网络号和主机号。不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。13.用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。写出C程序。 循环链表,用取余操作做14.不能做switch()的参数类型是: switch的
4、参数不能为实型。1. 以下三条输出语句分别输出什么?C易char str1 = abc;char str2 = abc;const char str3 = abc; const char str4 = abc; const char* str5 = abc;const char* str6 = abc;cout boolalpha ( str1=str2 ) endl; / 输出什么?0cout boolalpha ( str3=str4 ) endl; / 输出什么?0cout boolalpha ( str5=str6 ) endl; / 输出什么?12. 非C+内建型别 A 和 B,在哪
5、几种情况下B能隐式转化为A?C+中等答:a. class B : public A / B公有继承自A,可以是间接继承的b. class B operator A( ); / B实现了隐式转化为A的转化c. class A A( const B& ); / A实现了non-explicit的参数为B(可以有其他带默认值的参数)构造函数d. A& operator= ( const A& ); / 赋值操作,虽不是正宗的隐式类型转换,但也可以勉强算一个3. 以下代码中的两个sizeof用法有问题吗?C易void UpperCase( char str ) / 将 str 中的小写字母转换成大写字
6、母 for( size_t i=0; isizeof(str)/sizeof(str0); +I ) if( a=stri & stri=z ) stri -= (a-A );char str = aBcDe;cout str字符长度为: sizeof(str)/sizeof(str0) endl;UpperCase( str );cout str 9 ) ch += (A-9-1); char cl = c%0x10 + 0; if( cl 9 ) cl += (A-9-1); cout ch cl ;char str = I love 中国;for( size_t i=0; istrlen
7、(str); +I ) char2Hex( stri );cout endl;5. 以下代码有什么问题?C+易struct Test Test( int ) Test() void fun() void main( void ) Test a(1); a.fun(); Test b(); 答:Test b; b.fun();6. 以下代码有什么问题?C+易cout (true?1:1) temp;unsigned int const size2 = temp;char str2 size2 ;答:不能用变量 给const常量赋值8. 以下代码中的输出语句输出0吗,为什么?C+易struct C
8、LS int m_i; CLS( int I ) : m_i(i) CLS() CLS(0);答:在CLS()中CLS(0)创建了另一个对象,所以并没有对obj对象进行赋值,而是其他对象赋值。CLS obj;cout obj.m_i endl;不能,因为m_i没有初始化,会付一个很大的数,不太懂9. C+中的空类,默认产生哪些类成员函数?C+易答:class Emptypublic: Empty(); / 缺省构造函数 Empty( const Empty& ); / 拷贝构造函数 Empty(); / 析构函数 Empty& operator=( const Empty& ); / 赋值运算
9、符 Empty* operator&(); / 取址运算符 const Empty* operator&() const; / 取址运算符 const10. 以下两条输出语句分别输出什么?C+难float a = 1.0f;cout (int)a endl;cout (int&)a endl;不懂!cout boolalpha ( (int)a = (int&)a ) endl; / 输出什么?Float b = 0.0f;cout (int)b endl;cout (int&)b endl;cout boolalpha ( (int)b = (int&)b ) endl; / 输出什么?11
10、. 以下反向遍历array数组的方法有什么错误?STL易vector array;(vector没有给定具体类型也没有说明是模板类型) size_type 是无符号整数,当j=0时,做减1操作不会得到-1,而是得到最大的无符号整数,因此永远不会退出循环答:vector array(100);array.push_back( 1 );array.push_back( 2 );array.push_back( 3 );for( vector:size_type i=array.size()-1; i=0; -i) / 反向遍历array数组 cout arrayi endl;12. 以下代码有什么
11、问题?STL易typedef vector IntArray;IntArray array;array.push_back( 1 );array.push_back( 2 );array.push_back( 2 );array.push_back( 3 );/ 删除array数组中所有的2for( IntArray:iterator itor=array.begin(); itor!=array.end(); +itor ) if( 2 = *itor ) array.erase( itor );其实这里面隐藏着一个很严重的错误:当veci.erase(iter)之后,iter就变成了一个野
12、指针,对一个野指针进行 iter+ 是肯定会出错的。13. 写一个函数,完成内存之间的拷贝。考虑问题是否全面答:void* mymemcpy( void *dest, const void *src, size_t count ) char* pdest = static_cast( dest ); const char* psrc = static_cast( src );if( pdestpsrc & pdestpsrc+cout ) 能考虑到这种情况就行了判断拷贝是否有重叠区正确的拷贝 for( size_t i=count-1; i!=-1; -I ) pdesti = psrci;
13、else for( size_t i=0; icount; +I ) pdesti = psrci; return dest;int main( void ) char str = 0123456789; mymemcpy( str+1, str+0, 9 ); cout str _fun, main=_main但是C+中函数名与得到的汇编代号有比较大的差别。如:由于函数重载,函数名一样,但汇编代号绝对不能一样。为了区分,编译器会把函数名和参数类型合在一起作为汇编代号,这样就解决了重载问题。具体如何把函数名和参数类型合在一起,要看编译器的帮助说明了。这样一来,如果C+调用C,如fun(),则调
14、用名就不是C的翻译结果_fun,而是带有参数信息的一个名字,因此就不能调用到fun(),为了解决这个问题,加上extern C表示该函数的调用规则是C的规则,则调用时就不使用C+规则的带有参数信息的名字,而是_fun,从而达到调用C函数的目的。5、请简述以下两个for循环的优缺点/ 第一个for (i=0; i+;)if (condition)DoSomething();elseDoOtherthing();/优点:缺点 第二个if (condition)for (i=0; i+;)DoSomething();elsefor (i=0; i+;)DoOtherthing();优点:缺点:四、有
15、关内存的思考题(20分)void GetMemory(char *p)p = (char *)malloc(100);/没有free的操作肯定会造成内存泄漏void Test(void) char *str = NULL;GetMemory(str); strcpy(str, hello world);printf(str);请问运行Test函数会有什么样的结果?答:char *GetMemory(void)char p = hello world;/存储在stack中,但是stack中的变量在完成function之后会自动释放,所以也会返回一个野指针return p;void Test(vo
16、id)char *str = NULL;str = GetMemory(); printf(str);请问运行Test函数会有什么样的结果?答:Void GetMemory2(char *p, int num)*p = (char *)malloc(num);void Test(void)char *str = NULL;GetMemory(&str, 100);strcpy(str, hello); printf(str); 请问运行Test函数会有什么样的结果?答:void Test(void)char *str = (char *) malloc(100);strcpy(str, “he
17、llo”);free(str); if(str != NULL)strcpy(str, “world”); printf(str);请问运行Test函数会有什么样的结果?world答:五、编写strcpy函数(10分)已知strcpy函数的原型是:char *strcpy(char *strDest, const char *strSrc)其中strDest是目的字符串,strSrc是源字符串。(1)不调用C+/C的字符串库函数,请编写函数 strcpy(2)strcpy能把strSrc的内容复制到strDest,为什么还要char * 类型的返回值?为了实现链式表达式。char * strc
18、py( char *strDest, const char *strSrc ) assert( (strDest != NULL) &(strSrc != NULL) ); char *address = strDest; while( (*strDest+ = * strSrc+) != 0 ); return address; 从函数中返回函数体内分配的内存是十分危险的做法,他把释放内存的义务抛给不知情的调用者,绝大多数情况下,调用者不会释放内存,这导致内存泄漏。六、编写类String的构造函数、析构函数和赋值函数(25分)已知类String的原型为:class Stringpublic:
19、String(const char *str = NULL); / 普通构造函数String(const String &other); / 拷贝构造函数 String(void); / 析构函数String & operate =(const String &other); / 赋值函数private:char *m_data; / 用于保存字符串请编写String的上述4个函数。附录C :C+/C试题的答案与评分标准一、请填写BOOL , float, 指针变量 与“零值”比较的 if 语句。(10分)请写出 BOOL flag 与“零值”比较的 if 语句。(3分)标准答案:if ( f
20、lag )if ( !flag ) const float EPSINON = 0.00001;if (x = - EPSINON) & (x next = NULL; p=h; for(i=0;inext = s; printf(Please input the information of the student: name sex no age n); scanf(%s %c %d %d,s-name,&s-sex,&s-no,&s-age); s-next = NULL; p = s; printf(Create successful!); return(h);void deletel
21、ist(struct stu *s,int a)struct stu *p;while(s-age!=a) p = s; s = s-next;if(s=NULL) printf(The record is not exist.);else p-next = s-next; printf(Delete successful!);void display(struct stu *s)s = s-next; while(s!=NULL) printf(%s %c %d %dn,s-name,s-sex,s-no,s-age); s = s-next;int main() struct stu *s
22、;int n,age;printf(Please input the length of seqlist:n);scanf(%d,&n); s = creatlist(n); display(s);printf(Please input the age:n);scanf(%d,&age);deletelist(s,age);display(s); return 0;2、实现一个函数,把一个字符串中的字符从小写转为大写。 程序代码I nclude stdio.hI nclude conio.hvoid uppers(char *s,char *us) for(;*s!=0;s+,us+) if(
23、*s=a&*s=z) *us = *s-32; else *us = *s; *us = 0;int main() char *s,*us; char ss20; printf(Please input a string:n); scanf(%s,ss); s = ss; uppers(s,us); printf(The result is:n%sn,us); getch();1进程和线程的差别。2.测试方法 3Heap与stack的差别。4Windows下的内存是如何管理的?5介绍.Net和.Net的安全性。6客户端如何访问.Net组件实现Web Service?7C/C+编译器中虚表是如何完成的?8谈谈COM的线程模型。然后讨论进程内/外组件的差别。9谈谈IA32下的分页机制10给两个变量,如何找出一个带环单链表中是什么地方出现环的?11在IA32中一共有多少种办法从用户态跳到内核态?12如果只想让程序有一个实例运行,不能运行两个。像winamp一样,只能开一个窗口,怎样实现?13如何截取键盘的响应,让所有的a变成b?14Apartment在COM中有什么用?为什么要引入?15存储过程是什么?有什么用?有什么优点?16Template有什么特点?什么时候用?17谈谈Windows DNA结构的特点和优点。18.网络编程中设计并发服务器,使用多进程与多线程 ,请问有什么区别?
限制150内