金山 C++ 一面凉经

1. 自我介绍

2. vector 与 list 的区别与使用场景

  • vector:连续内存、随机访问快、尾插尾删快、CPU缓存友好
  • list:链表结构、任意位置插入删除快、迭代器不失效、随机访问慢
  • 场景:高频遍历/读多用 vector,频繁中间插入/删除用 list

3. vector push_back 均摊 O(1) 的原因

  • 采用指数扩容(1.5倍/2倍)策略
  • 扩容次数极少,所有插入的总拷贝次数为线性级
  • 均摊后每次插入的时间复杂度为 O(1)

4. inline 函数与宏的区别

  • inline:C++关键字,类型安全、可调试、无副作用、作用域安全
  • 宏:纯文本替换,无类型检查、易出错、调试困难
  • 现代C++优先使用 inline,弃用宏定义

5. 移动语义与完美转发

  • 移动语义:通过右值引用转移资源,避免深拷贝,提升性能
  • 完美转发:通过 std::forward 还原参数的左值/右值属性,实现通用转发
  • 核心:依赖引用折叠规则(T& + && → T&,T&& + && → T&&)

6. const 与 #define 的区别

  • const:C++关键字,有类型检查、作用域限制、可调试
  • define:预处理宏,纯文本替换、无类型检查、易出错
  • 现代C++优先使用const,弃用宏定义常量

7. 指针与引用的区别

  • 指针可空、可修改指向、支持多级指针
  • 引用必须初始化、不能为空、不可更换绑定对象
  • 引用本质是指针常量,使用更安全

8. new/delete 与 malloc/free 的区别

  • new/delete:C++运算符,会调用构造/析构函数、类型安全
  • malloc/free:C函数,仅分配/释放内存、无类型检查
  • 注意:new/delete 与 malloc/free 不可混用

9. 智能指针的理解与使用

  • unique_ptr:独占所有权,不可复制、可移动
  • s

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

C++ 常考面试题总结 文章被收录于专栏

本专栏系统梳理C++方向, 大中厂高频高频面试考点 , 内容皆来自真实面试经历,从基础语法、内存管理、STL与设计模式,到操作系统与项目实战,结合真实面试题深度解析,帮助开发者高效查漏补缺,提升技术理解与面试通过率,打造扎实的C++工程能力.

全部评论

相关推荐

自从来手子之后好久没面试了,这也是时隔近3个月的第一面,总体面试难度较低,面试官很温和,算是以赛代练开始暑期了,希望暑期能有好结果😘。1.讲一下redis数据结构。2.一般用什么比较多?3.为什么会用hash?(转到哈啰实习)4.redis在你们哈啰项目是做什么?5.讲讲什么是特征?6.你们的方案对redis跟数据库一致性要求有延迟,如果我不想有延迟有什么其他方案吗?7.有没有遇到过线上问题,怎么解决的?8.你怎么拆分的线程池?9.有监控吗?用ConcurrentHashMap考虑过内存问题吗?10.mysql索引11.索引底层数据结构12.优化mysql13.自己技术的优点跟缺点一个sql题,一个手撕难度都比较低,手撕是题目描述给定一个表示 大整数 的整数数组 digits,其中 digits 是整数的第 i 位数字。这些数字按从左到右,从最高位到最低位排列。这个大整数不包含任何前导 0。​将大整数加 1,并返回结果的数字数组。​智力题:一个圆桌,你先投硬币,一次只能投一个,咱们两个轮流把桌子投满,你怎么保证你肯定是桌子上硬币更多的一个人。总体来说答的很轻松,就是用公司电脑导致不能共享屏幕有点难绷,最后面完也是直接二面了,面试官说业务是用户增长,负责拉新和唤醒活动,得转go和py。但是是日常实习,加上在北京200一天,估计是不会去的,但是练手是还可以的。PS:今天是高考1000天了,时间真的过得好快,高中真是不可多得的幸福时光啊,要是高考考好点就好了。
查看13道真题和解析
点赞 评论 收藏
分享
评论
1
4
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务