C++ 面试真不难,反反复复都是这些题

前言

C++ 面试看起来题量大、跨度广,从语法细节到 STL、从内存管理到并发,好像永远复习不完。实际面下来会发现:高频题就那些类型,换公司、换岗级,只是在深度和场景上略有差别。

难点通常不在「有没有见过」,而在三件事:

  • 基础是否扎实,能不能讲清楚原理而不是背定义
  • 能不能把语言和项目经验连起来(为什么用 shared_ptr、为什么这里不用异常)
  • 手写/口述代码时思路是否清晰,边界条件会不会漏

所以复习不必贪多求全,按模块过一遍经典题 + 自己讲一遍,性价比最高。

准备策略

1. 先划模块,再刷题

建议顺序:语言基础 → 面向对象 → 内存与智能指针 → STL → 并发与 C++11/14/17 → 杂项(关键字、UB、工程实践)。每个模块挑代表题吃透,比漫无目的刷几百道更有效。

2. 每道题至少能答三层

  • 是什么(结论)
  • 为什么(原理、标准规定)
  • 怎么用 / 坑在哪(项目里怎么选)

3. 手写代码要练

vector 扩容思路、单例写法、shared_ptr 控制块、移动构造、生产者消费者——面试常让写骨架或口述实现,只背概念不够。

4. 结合简历项目

每道常考题准备一句「我在 XX 里怎么用的 / 为什么不用 YY」,面试官会明显觉得你是真写过 C++ 的。

5. 时间分配参考(约 2~3 周业余)

  • 第 1 周:基础 + OOP + 内存(占 40%)
  • 第 2 周:STL + 现代 C++ 特性(占 35%)
  • 第 3 周:并发 + 模拟面试 + 错题回顾(占 25%)

核心大厂开发面试题以及基础八股文资料汇总:

https://www.nowcoder.com/creation/manager/columnDetail/Mq7XWW

高频面试题

语言基础

  1. C 和 C++ 的主要区别有哪些?
  2. struct 和 class 在 C++ 里有什么区别?
  3. const 关键字有哪些常见用法?
  4. static 关键字在全局变量、局部变量、类成员、类函数上分别什么含义?
  5. #define 和 constenuminline 相比各有什么优劣?
  6. 指针和引用的区别?什么场景必须用引用/指针?
  7. 函数指针和 std::function 的区别?
  8. 左值、右值、左值引用、右值引用分别是什么?
  9. 什么是移动语义?std::move 做了什么?
  10. 深拷贝和浅拷贝的区别?什么时候必须自定义拷贝构造/赋值?

面向对象

  1. 面向对象的三大/四大特性是什么?
  2. 构造函数、析构函数、拷贝构造、拷贝赋值的调用顺序?
  3. 什么是虚函数?虚函数表(vtable)大致怎么工作?
  4. 纯虚函数和抽象类是什么?
  5. 虚析构函数为什么重要?
  6. 重载、重写(覆盖)、隐藏的区别?
  7. 公有继承、保护继承、私有继承在访问权限上有什么不同?
  8. 多继承有什么问题?菱形继承和虚继承了解吗?
  9. 运算符重载有哪些限制和注意事项?
  10. explicit 关键字解决什么问题?

内存与资源管理

  1. 堆和栈的区别?哪些对象在栈上、哪些在堆上?
  2. new / delete 与 malloc / free 的区别?
  3. 什么是内存泄漏?常见原因有哪些?
  4. 野指针、悬空指针分别是什么?
  5. RAII 是什么?在 C++ 里怎么体现?
  6. 智能指针 unique_ptrshared_ptrweak_ptr 的区别和使用场景?
  7. shared_ptr 线程安全吗?引用计数如何理解?
  8. 为什么要用 make_shared / make_unique
  9. 自定义 deleter 用在什么场景?
  10. 什么是 Rule of Three / Rule of Five?

STL 与算法

  1. STL 六大组件(或常见容器)有哪些?
  2. vector 底层实现?扩容策略和复杂度?
  3. vector 中 push_back 和 emplace_back 的区别?
  4. list 和 vector 怎么选?
  5. map 和 unordered_map 底层与复杂度、使用场景?
  6. set 里元素能不能修改?为什么?
  7. 迭代器失效是什么?哪些操作会导致失效?
  8. 函数对象(仿函数)和 lambda 的捕获方式有哪些?
  9. std::sort 用什么算法?自定义比较要注意什么?
  10. 容器遍历中删除元素的正确做法?

并发与现代 C++

  1. 进程和线程的区别?
  2. 线程同步有哪些方式(互斥锁、条件变量等)?
  3. mutexlock_guardunique_lock 的区别?
  4. 什么是死锁?如何避免?
  5. atomic 解决什么问题?能保证什么、不能保证什么?
  6. thread 创建线程时要注意什么(传参、join/detach)?
  7. volatile 和原子操作、内存序的关系?(常考误区)
  8. C++11 里 nullptr 为什么比 NULL 好?
  9. 范围 for 循环底层大致怎么用迭代器实现?
  10. autodecltype 分别用在什么场景?

结尾

这 50 道题覆盖了大部分 C++ 初~中级面试的主干。不必每道都背标准答案,能用自己的话讲清、能举项目例子、能手写关键代码,比刷题量更重要。

全部评论

相关推荐

05-29 13:25
门头沟学院 Java
努力勤奋的马洛格已躺...:没有实习就找不到实习
点赞 评论 收藏
分享
在我来鹅之后,接到的第一个完整大需求就是需要编写一个skill,之前的实习也写过一些skill,但是在我的理解中skill就是跟提示词没差,把你需要的目标全写上就好了,所以第一次mr我提交了一个超过1200行的md,被mt打了回去,为了完成这个需求,我又赶紧请教了我身边的大神同学,获取一些写skill的经验,将原先1200行的md进行了对应的references拆封,又通过我朋友教我的验证机制验证这个skill的效果,最后完成了我的第一个需求。正好前两篇文章给大家分享了写好的用来包装简历的skill,那么今天来给大家分享怎么去写一个好的,可以实际用来工作的skill,摆脱只会写提示词的尴尬。构建 Skill 的五个步骤Step 0:先写 EvalsEval(Evaluation,评估)是一套结构化的、可重复运行的测试用例集,用来判断 Skill 的表现是否符合预期。它不是泛指"测试一下",而是开发 Skill 的前提条件。一个典型的 Skill eval 集至少包含三类用例:- 正例(Positive):用户说“帮我看一下这个 PR 能不能合”,验证 Skill 应该被加载- 负例(Negative):用户说“帮我把代码格式化一下”,验证 Skill 不该被加载——路由别跑偏到不该触发的地方- 边界(Edge):“这个 PR 改了一行日志,要不要审”,验证边界情况下的路由行为正例和负例都要写,而且负例往往比正例更值钱——误触发是 Skill 路由的头号失败模式。Eval 不只是测一次。Perplexity 的 eval 分三个层次:如下图每种都要在 GPT、Claude Opus、Claude Sonnet 不同的 orchestration 模型上分别跑——Sonnet 和 GPT 的 Skill 行为差异很大,只在一种模型上过了不够。没有 evals,你改 description 就是在盲改,一个新 Skill 也可能悄悄搞坏已有的十个 Skill。Step 1:写 Description(最难的一行)description 是路由触发器,不是文档。写好它不需要关心 Skill 的内容,只需要关心能不能在正确的时间加载、有没有意外触发到不应该触发的地方——误触发是头号失败模式,每加一个 Skill 都有可能让其他 Skill 变差。糟糕的 description 描述 Skill 做什么,好的 description 说什么时候加载。举个监控 PR 的例子:不要写这个 Skill 做什么,要写工程师感到焦虑时会说什么——"babysit"、"watch CI"、"make sure this lands"。快速检查清单:- 以"Load when…"开头- 控制在 50 词以内- 描述用户意图,最好来自真实查询- 不总结工作流程Step 2:写 Body跟同事讲工作流程和跟 LLM 讲工作流程完全是两回事。对几乎任何面世超过一年的软件工具,只要提名字,模型已经知道怎么用。所以跳过模型已经懂的部分。不用写出每一步命令。比如不要写 git log → git checkout main → git checkout -b clean-branch → git cherry-pick commit。写 "Cherry-pick the commit onto a clean branch. Resolve conflicts preserving intent. If it can't land cleanly, explain why." 模型在后者上表现好得多,尤其是事情不按预期走的时候。太规定的指令比灵活的指令更脆弱。然后聚焦 gotchas 和反例,它们是最高信噪比的内容。每次 Agent 搞砸了就加一条,gotcha 会自然地累积起来。条件逻辑或内容太重的东西移出 SKILL.md,放到 accessory file 里渐进加载。Step 3:用层级结构- scripts/ —— 确定性逻辑,模型不用每次重新发明- references/ —— 重型文档,条件触发才读("如果 API 返回非 200,读 api-errors.md")- assets/ —— 输出模板,模型直接复制填充- config.json —— 首次运行设置,问一次保存下来对于极其复杂的 Skill,进一步考虑是否应该拆成一组 Skill,用 depends: 声明加载关系。Step 4:迭代切分支出来,在无 Skill 的状态下跑 hero query(核心用户场景查询),建 eval 集,反复调。提交 review 时最好一个 changeset 里自带 eval 集。Description 里的小词改动对路由影响很大,甚至会 spillover(溢出)到其他 Skill,所以这些在 Step 5 之前做完。Step 5:发布大家快把这5步实行起来,成为写skill专家吧!
琉璃梦忆:直接skill creator 管你这那的
AI了,我在打一种很新的...
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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