欢迎来到天天文库
浏览记录
ID:19049343
大小:18.51 KB
页数:13页
时间:2018-09-28
《阿里云 面试 流程》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、阿里云面试流程 电话问题1:构造和析构函数中的虚函数调用; 答案:虚函数可以在构造函数和析构函数中调用,但虚函数此时是静态绑定;而非动态绑定。 电话问题2:C++中的异常可不可以是引用; 答案:异常可以是引用,并且效率高。 电话问题3:TCP状态中的close_wait是什么状态; 答案:close_wait状态是被动关闭方的一个状态,此时是半关闭状态,被关闭方收到了Fin包,并且发送了fin包的ack,等待上层应用结束连接。 电话问题4:排序算法的时间复杂度; 答案:最好是nLogn,其他的上网搜索。 面试问题函数编写; 答案: 自己写的
2、atoi函数----(注意:自己定义的atoi函数和库的atoi函数一样的时候,抛出异常时会引起异常退出,个人认为是异常没有不知道被那个函数抛出,所以coredump) #include #include #include #include #include #include #include #include usingnamespacestd; constunsignedintSIGN_BIT=0x1 boolisDigit(constcharch) { if(ch='0') { returntrue; } returnfa
3、lse; } intatoi_i(constchar*str) { assert(str!=NULL); while(''==*str){str++;} intresult=0; boolsignFlag=false; if('+'==*str) { if(false==isDigit(*++str))throw"inputformaterror!"; } elseif('-'==*str) { if(false==isDigit(*++str))throw"inputformaterror!"; signFlag=true; }
4、 elseif(*str>'9'
5、
6、*str { throw"inputformaterror!"; } do { result=result*10+*str++-'0'; if((result&SIGN_BIT)!=0) { throw"overflowerror!"; } } while(isDigit(*str)); if(true==signFlag) { result=-result; } returnresult; } intmain(intargc,char*argv) { charinput; whi
7、le(1) { try { cout cin>>input; printf("exchange:%d/n",atoi_i(input)); } catch(constchar*p) { cout } catch(...) { cout } } return0; } 本文来自CSDN博客,转载请标明出处:http:///zhangxinrun/archive/XX/12/01/ 面试问题和空类; 答案: classCBase { inta; char*p; }; 那么运行cout 这个应该很简单,两个成员变量
8、所占的大小——8。 第一步:空类 classCBase { }; 运行cout sizeof(CBase)=1; 深度探索c++对象模型中是这样说的:那是被编译器插进去的一个char,使得这个class的不同实体(object)在内存中配置独一无二的地址。也就是说这个char是用来标识类的不同对象的。 第二步: 还是最初的那个类,运行结果:sizeof(CBase)=8 第三步:添个虚函数 classCBase { public: CBase(void); virtual~CBase(void); private: inta;
9、 char*p; }; 再运行:sizeof(CBase)=12 C++类中有虚函数的时候有一个指向虚函数的指针(vptr),在32位系统分配指针大小为4字节”。那么继承类呢? 第四步: 基类就是上面的了不写了 classCChild: publicCBase { public: CChild(void); ~CChild(void); private: intb; }; 运行:cout 输出:sizeof(CChild)=16; 可见子类的大小是本身成员变量的大小加上子类的大小。 面试问题3.(1)对象只允许在堆上创建,(2
10、)对象只允许在栈上创建;
此文档下载收益归作者所有