腾讯C++二面,全程2小时追问基础!

今天给大家分享星球一位同学腾讯面经,主要摘取了部分一二面经,然后部分问题我做了补充说明~

星球原文:https://t.zsxq.com/0eO4O13HV,已获授权

一面

1、C++11有哪些新特性,有哪些新关键字

2、C++中结构体占多少字节(考字节对齐):

struct{
  char a;
  int b;
  double c;
  char d;
}

补充:
关键的几点判断依据在《C++面试指北》中有总结:

3、C++空类对象的大小

同样《C++面试指北》也有总结,主要因为C++标准要求每个对象都必须具有独一无二的内存地址。

为了满足这一要求,编译器会给每个空类分配一定的空间,通常是1字节:

4、C++多态有几种实现机制(当时没怎么懂,可能泛型编程也算多态?)

5、C++析构函数为什么需要是虚函数,析构顺序是什么

补充:
多态和虚函数《C++面试指北》也有总结:

6、C++中为什么要引进nullptr(当时没答出来,面试官说是方便类型推断

补充:

  1. 类型安全性:nullptr是一种特殊的空指针类型,可以与整数类型区分开来,可以避免将整数0错误地解释为空指针。
  2. 重载决议:nullptr可以与其他指针相关的重载函数进行区分。例如,如果有两个函数重载,一个接受整数参数,另一个接受指针参数,传递nullptr将调用接受指针参数的函数:

7、epoll、select、poll区别是什么,内部原理

IO 复用基本是后台面试必问题了,可以去多搜一些博客看下,Java 会结合 Netty 问。

8、TCP四次挥手过程,TIME_WAIT 时长,为什么需要有 TIME_WAIT

9、算法题:求a的n次方(不能用O(n)复杂度的)

二面

今天下午面了腾讯的二面,时长2小时20分钟(其中大部分时间是在写代码,面试官边看着我写边询问思路),放眼我的整个面试经历也是相当之炸裂,基本上都是在问C++基础。

我到现在面过5家公司,其他的都没问过C++,基本上都是在问网络、操作系统和数据库,只有腾讯一面二面都是在问C++基础,虽然面试时间巨长,但是收获颇丰,跟大家分享一下(回答):

1. C++里面 new/delete 和 malloc/free 有什么不同?

补充:

  1. 语法层面:newdelete是C++中的运算符,可以被重载,而malloc()free()是C语言中的函数
  2. 构造和析构函数的调用:使用new/delete时,会自动调用对象的构造函数和析构函数。malloc()free()则不会。
  3. 内存分配失败的处理:new在内存分配失败时会抛出std::bad_alloc异常,malloc()在分配失败时返回空指针NULL
  4. 内存大小计算:使用new时,不需要手动指定要分配的内存大小,会根据所需类型自动计算大小。malloc()需要显式指定要分配的字节数。

2. 知道C++的野指针是什么吗,什么情况下会出现野指针?(未初始化或指针指向的内存被delete掉了)

补充:

返回局部变量的指针:将指针指向一个局部对象,然后在对象超出作用域后继续使用该指针,也会导致野指针的出现,常出现在返回局部变量的引用/指针。

3. delete a; delete是怎么知道需要释放的指针a指向的对象的大小的

补充:

delete 和 free 是相似的,当使用new操作符分配内存时,编译器会在分配的内存块的开头存储一些额外的信息,其中就包括内存块的大小。

这些信息用于在释放内存时确定要释放的字节数。

引用CSAPP 中的图示:

一个简单的分配内存块的格式

4、如果申请了内存但忘记释放会造成内存泄漏,用什么方法避免(智能指针)

补充:

  1. 使用C++中的智能指针(如std::unique_ptrstd::shared_ptr)来管理动态分配的内存,即RAII机制,利用对象析构的确定性来确保退出作用域时一定会释放内存

  2. 使用内存分析工具,如 Valgrind 来检测和识别内存泄漏问题

5. 代码:写一个智能指针(shared_ptr)

补充:

实现一个简单的 shared_ptr类,主要两个成员变量:

  • 指向对象的指针:用于保存要管理的对象的地址。

  • 引用计数:用于记录当前有多少个shared_ptr共享同一个对象,引用计数需要使用指针来在多个shared_ptr 对象之间共享计数,实际上比这个复杂,一般是一个类对象,内部包含多个引用计数相关的信息:

几个关键点:

  • 析构函数:在析构函数中处理引用计数的递减和内存的释放。
  • 重载解引用操作符
  • 为了实现共享所有权,需要编写拷贝构造函数和拷贝赋值运算符:
    • 在拷贝构造函数中,将指向对象的指针和引用计数成员变量复制到新对象,并递增引用计数。
    • 在拷贝赋值运算符中,处理自我赋值情况并更新引用计数。

星球专栏《C++面试指北》中,也有手写的示例:

6、代码:知道weak_ptr吗,能不能实现weak_ptr(虽然是实现了,但是面试官不太满意)

补充:

weak_ptr 主要是用来解决 shared_ptr 循环引用问题,除了解决相互引用的问题,weak_ptr还适用一切应该不具有对象所有权,又想安全访问对象的情况。

对于具体实现,关键步骤其实也在上面那一张图里,和 shared_ptr 类似,需要内部管理一个引用计数类,并且weak_ptr 接受一个 shared_ptr 进行构造,然后和 shared_ptr 共享一个引用计数类, weak_ptr 的复制和拷贝只增加 weak_count (弱引用),在解引用之前,需要通过 lock 函数获取一个 shared_ptr ,如果 use_count 计数已经清零,则 lock 返回 nullptr。

7、代码:能不能在不声明临时变量的情况下求得字符串的长度(这题当时没写出来,主要是没太懂意思,在网上看了看搜了搜都是用递归写的,当时以为要尽量节省空间,就没往递归的方向去想)

8、代码:知道单例模式吗,能不能写一个单例模式的代码

补充:

经典的饿汉式、懒汉式、双重检测。

见:https://csguide.cn/designpattern/1_singleton.html

9、模板偏特化知道吗,偏特化的目的是什么

10、代码:能不能实现一个简单的 vector

11、代码:给你两个单向链表,一个是升序一个是降序,将两个链表合并成一个升序链表

12、C++里面调用C的函数时会用到extern C,为什么不能直接调用

补充:这里在 《C++面试指北》 中有解释,具体和 C++ 的Name mangling 有关:

13、C++内存分配机制是怎样的,哪些变量在栈上分配空间,哪些在堆上分配

14、函数的调用过程,从函数调用返回后怎么知道下一行代码的执行位置(调用函数时会将下一条指令的地址压栈)

15、大学看过哪些深入解析原理的书,类似于STL源码剖析这种的

16、你觉得你是一个什么样的人

17、在学校的成绩怎么样

18、刚才你说你在学校的成绩中等,那些成绩比你好的同学是怎么学习的你有了解过吗

19、有没有考研的打算

还有一部分提问忘掉了,印象比较深刻的问题都在上面,面试官在面试过程中有提到过我打代码时变量的命名太过随意。

所以大家在面试中做题还是要规范代码,不要追求速度。


总结:

基本上 C++ 语言问的问题都主要集中在《C++面试指北》中总结的这几块:

语言和操作系统最容易结合的也是多线程、内存管理。

除此以外就是网络中的 TCP、IO模型,这些是大厂 C++ 后台方向特别爱问的。

可以看一下星球里的专栏《C++面试指北》

这是小北亲自整理和原创的C++ 面试八股文,基本涵盖 C++ 语言常问的问题,力争给大家讲懂每一个高频考点,不单单有文字描述,还有代码示范、画图,以及扩展学习这个知识点该去看什么书,看什么博客:

  • 6
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值