欢迎来到天天文库
浏览记录
ID:12617675
大小:622.50 KB
页数:56页
时间:2018-07-18
《c c++语言面试宝典(保证你通过面试)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、安徽高新嵌入式教育中心skyino1整理希望能给你带来光明的前途Qq:912886544www.embedcn.com找工作感言学生该找工作了,天天到处奔波,最让人伤心的是求职未果,真的,还未步入职业生涯,已经身心疲倦了,好累!现在求职的状态就是高不成低不就,与专业无关的职业很多,但不想去做,因为觉得在其他行业中找不到乐趣,也体现不了价值,而专业方面的职业也有,但是有好多机会都与擦肩而过,由于知识面的狭窄,很难通过笔试那一关。在网上看了很多招聘信息,有很多职位都望而生畏,其本质原因就是知识面不广,实践经验不够丰富。
2、半个月,后就像无头苍蝇,到处乱撞,现在需要静下心来仔细思考一下!对于找工作,是不是也应该换个角度去考虑呢?总结屡面屡败的原因,最核心的就是两方面的问题,一是笔试,二是实践经验。个人认为笔试最重要,如果笔试成绩排在前面,在随后的面试中,压力就非常小。现在市面上有流行的程序员面试宝典,程序面试宝典,可惜不知为什么,错误太多,而且覆盖面不广,这里参加的笔试、面试题,以及一些资料上的经典题目进行汇总,整理为120多个。希望对大家找工作有所帮助,如有疑问,谢谢!你真诚的朋友:左老师1.new、delete、malloc、fr
3、ee关系delete会调用对象的析构函数,和new对应free只会释放内存,new调用构造函数。malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符。它们都可用于申请动态内存和释放内存。对于非内部数据类型的对象而言,光用maloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加于malloc/free。因此C++语
4、言需要一个能完成动态内存分配和初始化工作的运算符new,以及一个能完成清理与释放内存工作的运算符delete。注意new/delete不是库函数。2.delete与delete[]区别delete只会调用一次析构函数,而delete[]会调用每一个成员的析构函数。在MoreEffectiveC++中有更为详细的解释:“当delete操作符用于数组时,它为每个数组元素调用析构函数,然后调用operatordelete来释放内存。”delete与New配套,delete[]与new[]配套MemTest*mTest1=
5、newMemTest[10];MemTest*mTest2=newMemTest;int*pInt1=newint[10];int*pInt2=newint;delete[]pInt1;//-1-delete[]pInt2;//-2-delete[]mTest1;//-3-delete[]mTest2;//-4-在-4-处报错。安徽高新嵌入式教育中心skyino1整理希望能给你带来光明的前途Qq:912886544www.embedcn.com这就说明:对于内建简单数据类型,delete和delete[]功能是相同
6、的。对于自定义的复杂数据类型,delete和delete[]不能互用。delete[]删除一个数组,delete删除一个指针简单来说,用new分配的内存用delete删除用new[]分配的内存用delete[]删除delete[]会调用数组元素的析构函数。内部数据类型没有析构函数,所以问题不大。如果你在用delete时没用括号,delete就会认为指向的是单个对象,否则,它就会认为指向的是一个数组。3.CC++JAVA共同点,不同之处?4.继承优缺点。类继承是在编译时刻静态定义的,且可直接使用,类继承可以较方便地改
7、变父类的实现。但是类继承也有一些不足之处。首先,因为继承在编译时刻就定义了,所以无法在运行时刻改变从父类继承的实现。更糟的是,父类通常至少定义了子类的部分行为,父类的任何改变都可能影响子类的行为。如果继承下来的实现不适合解决新的问题,则父类必须重写或被其他更适合的类替换。这种依赖关系限制了灵活性并最终限制了复用性。(待补充)5.C++有哪些性质(面向对象特点)封装,继承和多态。在面向对象程序设计语言中,封装是利用可重用成分构造软件系统的特性,它不仅支持系统的可重用性,而且还有利于提高系统的可扩充性;消息传递可以实现
8、发送一个通用的消息而调用不同的方法;封装是实现信息隐蔽的一种技术,其目的是使类的定义和实现分离。6.子类析构时要调用父类的析构函数吗?析构函数调用的次序是先派生类的析构后基类的析构,也就是说在基类的的析构调用的时候,派生类的信息已经全部销毁了定义一个对象时先调用基类的构造函数、然后调用派生类的构造函数;析构的时候恰好相反:先调用派生类的析构函数、然后调用基类
此文档下载收益归作者所有