C++面试题目及答案.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

C++面试题目及答案

1.问题:C++中变量的存储区域有哪些?分别存储什么内容?

答案:主要分4个区域:

栈区(Stack):存储函数局部变量、函数参数,由编译器自动分配释放,比如voidfunc(){inta=10;}中的a就存在栈区,函数结束后自动销毁。

堆区(Heap):需手动通过new/malloc分配、delete/free释放,比如int*p=newint(20);,p指向的内存在堆区,若不手动释放会导致内存泄漏。

全局/静态区(DataSegment):存储全局变量、静态变量(static修饰),程序启动时分配,结束时释放,比如intg_val=30;staticints_val=40;。

常量区(RoDataSegment):存储字符串常量、const修饰的全局常量,比如constchar*str=hello;中的hello,内容不可修改,修改会触发运行时错误。

2.问题:const在C++中有哪些用法?请举例说明

答案:主要3种核心用法,重点区分修饰对象的不同维度:

修饰变量:变量值不可修改,比如constinta=5;a=6;(编译报错),若修饰指针分两种:

指针指向的值不可改:constint*p=a;*p=7;(报错),但指针本身可改:p=b;(合法)。

指针本身不可改:int*constp=a;p=b;(报错),但指向的值可改:*p=7;(合法)。

修饰函数参数:防止函数内部修改参数值,比如voidprint(constintnum){num=10;}(编译报错),常用于传递大对象(如conststrings)避免拷贝,同时保护数据。

修饰类成员函数:表示函数不修改类的成员变量(mutable修饰的成员除外),比如:

classTest{

public:

intval;

voidshow()const{//常成员函数

val=10;//报错,不可修改普通成员

}

};

注意:常对象(constTestt;)只能调用常成员函数,普通对象可调用常/非常成员函数。

3.问题:C++中new和malloc的区别是什么?

答案:核心区别在“是否面向对象”和“功能完整性”,实际开发中优先用new:

分配方式:malloc是C标准库函数,需指定字节数(malloc(4));new是C++运算符,直接指定类型(newint),无需手动计算大小。

初始化:new可直接初始化(newint(10)),malloc只分配内存不初始化,默认是随机值。

类型安全:new返回对应类型指针(int*),malloc返回void*,需强制转换((int*)malloc(4)),可能因类型不匹配隐藏错误。

类对象处理:new会调用类的构造函数,delete调用析构函数;malloc/free仅操作内存,不调用构造/析构,若用于类对象会导致成员初始化失败或资源泄漏(比如类内有new分配的内存)。

异常处理:new分配失败抛bad_alloc异常,malloc失败返回NULL,需手动判断(if(p==NULL))。

4.问题:什么是智能指针?unique_ptr和shared_ptr的区别是什么?

答案:智能指针是封装裸指针的类,通过RAII(资源获取即初始化)自动释放内存,避免泄漏,C++11后主要有unique_ptr、shared_ptr、weak_ptr。

两者核心区别在“所有权”:

unique_ptr:独占所有权,同一时间只能有一个unique_ptr指向同一内存,不支持拷贝(unique_ptrintp1=p2;报错),仅支持移动(unique_ptrintp1=move(p2);,移动后p2失效),适合管理“唯一归属”的资源(比如函数内动态创建的对象,返回时用move传递)。

shared_ptr:共享所有权,多个shared_ptr可指向同一内存,内部通过“引用计数”管理,每拷贝一次计数+1,每销毁一个计数-1,计数为0时自动释放内存,支持拷贝(shared_ptrintp1=p2;合法),但需注意“循环引用”问题(比如A和B互相持有shared_ptr,会导致计数永远不为0,内存泄漏,需用weak_ptr解决)。

示例:

//unique_ptr示例

unique_ptrintup(newint(10));

unique_ptrintup2=move(up);//合法,up失效

//shared

文档评论(0)

151****9429 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档