阿里 / 百度 / 快手 / 网易 / 小红书实习面经合集

个人在七月份的一些实习面经~

P.S. 都是实习!实习!实习面试!重要的事情说三遍!!!

阿里夸克(搜索引擎 - C++)

C++:

  • 左值引用和右值引用
  • std::move()

LeetCode:

  • 多数元素(No. 169)

百度(音频引擎 - C++)

C++:

  • const 指针
  • constexptr 与 const 指针的区别(编译时进行常量的求值和运算)
  • new 和 malloc 的区别(类型安全、构造和析构、分配失败处理、大小计算)
  • 内存对齐(变量、函数、虚函数、静态变量、嵌套结构体)
  • vector 数组和普通数组的区别(要点:为何能追加元素)
  • vector 如何判断应该扩容(size 和 capacity)
  • vector clear() 是清空所有元素还是清空内存
  • 如何真正的清空 vector 内存(提示:与空 vector 做 swap 操作)
  • map 和 unordered_map 的底层实现、区别、查找的时间复杂度、应用场景
  • map 插入一个元素的时间复杂度(O(logn)
  • 类中 static 函数能否声明为虚函数(不能)
  • 构造函数能否声明为虚函数(不能)
  • 还有哪些函数不能声明为虚函数(内联函数、友元函数、非成员函数)
  • 如何保证类的对象只能被开辟在堆上(提示:将构造函数声明为私有、单例)
  • C++ 源文件编译流程(预编译 .i、编译 .o、汇编 .s、链接 .exe

Linux:

  • 查看指定进程占用的端口号(netstat & grep)
  • 打印某一列并按空格分隔(awk -F

MySQL:

  • MVCC 实现原理
  • 幻读是什么
  • 如何解决幻读问题(间隙锁)

OS:

  • 如何使用 gdb 排查多线程中哪个函数出现了死锁(info thread & thread 2 & bt
  • 一个线程会发生死锁吗(比如:多次尝试同一个锁、递归获取锁)
  • select / poll / epoll 的区别
  • epoll 底层实现
  • ET 和 LT 的区别

LeetCode:

  • 前 K 个高频元素(No. 347)

Expand:

  • 静态绑定和动态绑定
  • 虚函数表在哪个阶段被分配的(编译)
  • 虚函数表存在哪个区(常量区)
  • delete 和 free 的区别(类型检查)
  • push_backemplace_back 的区别
  • 浅拷贝和深拷贝的区别(举例说明)

快手(AI 软件开发 - Java - 一面)

Kafka:

  • 与其他消息队列相比、为什么 Kafka 性能更好(批量处理和异步、每秒千万级)
  • 多副本备份(Replica)
  • 主节点挂了怎么办(选举新的主节点)
  • 新的主节点是如何选举的(Zookeeper 一致性协议选举)
  • Kafka 基本架构(Broker、Topic、Partition、Group)

Redis:

  • ZSet 底层实现(跳表)
  • 介绍一下跳表及其插入、查找、删除的时间复杂度(均为 O(logn)
  • 过期淘汰策略(惰性删除 + 定期删除)
  • 持久化策略(AOF 和 RDB)
  • 主从节点如何同步数据(RDB 全量 + AOF 增量)
  • 一个新加入的从节点如何追上主节点(增加从节点性能、减少主节点写负载)

Network:

  • 介绍一下三次握手和四次挥手
  • 为什么不能是三次挥手(需要传输和处理数据)
  • 第一次握手可以传输数据吗(不可以)

gRPC:

  • 与 HTTP 相比 gRPC 的优点
  • HTTP 和 gRPC 哪个传输效率更高

MySQL:

  • 什么是聚簇索引
  • 聚簇索引和普通索引有什么区别
  • B+ 树和 B 树有什么区别
  • 什么是覆盖索引
  • 什么是回表
  • 解释一下不可重复读、脏读、幻读以及在什么情况下会出现
  • 如何解决幻读(间隙锁)

Personal:

  • Redis 分布式锁是如何实现的
  • Callback 回调函数是同步还是异步的

LeetCode:

  • 二叉树最大宽度(No. 662)
  • 环形链表(No. 141)

小红书(机器学习平台开发 - C++)

C++:

  • 介绍一下虚函数(多态)
  • 如何用 C 语言实现 C++ 虚函数(定义虚函数表、初始化虚函数表指针)
  • static 关键字
  • 能否在普通函数内部声明 static 变量、作用是什么(可以、全局变量)
  • 什么是内联函数(将函数代码直接插入到调用点、例如 add(x, y) 直接变为 x + y
  • 内联函数为何能提升执行效率、举例说明(普通函数需要传递参数、创建和销毁栈帧)
  • 一次函数调用在编译过程是什么样的(关键:将函数返回地址压入堆栈或寄存器中)

Shell:

  • grep & awk

LeetCode:

  • 滑动窗口最大值(No. 239)

快手(AI 软件开发 - Java - 二面)

Golang:

  • 如何理解 Go 线程和协程(协程是轻量级线程)
  • 为什么 goroutine 性能更好(轻量级、并发调度、channel)
  • 什么业务需求要开 goroutine
  • 普通的加减乘除(函数)计算需要单独开一个 goroutine 吗
  • n 个协程和一个协程做计数哪个效率更高

OS & Network:

  • 如何判断服务器性能是否符合预期、或达到性能瓶颈
  • 客户端(多线程)和服务器(多线程)通信需要建立几个 TCP 连接(一个)
  • 服务器如何区分来自客户端不同进程的 TCP 报文(源 IP 和端口号)

网易(全栈开发)

Docker:

  • 介绍一下底层 cgroup 和 namespace
  • 经常使用哪些命令

MySQL:

  • 说一下表锁和行锁
  • 写一个能够触发行锁的 SQL 语句
  • 什么情况下能触发记录锁、是否需要为索引

Golang:

  • goroutine 异常退出能释放 Redis 分布式锁吗(不能)

Expand:

  • join 和 detach 线程的区别(join 阻塞等待、detach 后台运行)
#我的实习求职记录#
全部评论
你怎么什么都会😨😨
5 回复 分享
发布于 2023-07-29 20:35 北京
tql 今天对着这个面经补了一整天
3 回复 分享
发布于 2023-07-30 21:04 广东
干活满满,火速学习
3 回复 分享
发布于 2023-07-29 19:17 广东
真牛啊
2 回复 分享
发布于 2023-07-31 20:33 北京
校友牛的👍
1 回复 分享
发布于 2023-08-07 09:49 陕西
牛逼
1 回复 分享
发布于 2023-08-02 23:22 湖北
佬真的无时无刻不在面试
1 回复 分享
发布于 2023-08-02 18:37 北京
太强了
1 回复 分享
发布于 2023-08-02 17:16 浙江
佬的八股,是我可望而不可及的水平
1 回复 分享
发布于 2023-08-02 15:52 上海
“如何保证类的对象只能被开辟在堆上(提示:将构造函数声明为私有、单例)” 老哥这题不全哦,是将析构函数声明为私有 可以让类对象只被开辟在堆上。因为栈上变量需要自动调用析构函数。
1 回复 分享
发布于 2023-07-31 12:56 北京
太强了吧全栈人才
1 回复 分享
发布于 2023-07-31 01:31 上海
你真的好猛啊
1 回复 分享
发布于 2023-07-31 00:18 广东
tql 今天对着这个面经补了一整天
1 回复 分享
发布于 2023-07-30 21:43 广东
1 回复 分享
发布于 2023-07-30 17:08 上海
1 回复 分享
发布于 2023-07-29 22:21 广东
阿里就这么点吗 不会全部问项目吧
点赞 回复 分享
发布于 2023-09-10 00:36 北京
m
点赞 回复 分享
发布于 2023-08-21 11:49 广东
同学,阿里控股集团JAVA开发岗投吗?我们和其他业务集团独立招聘,可以多次机会。需要的话,可以联系我。
点赞 回复 分享
发布于 2023-08-15 19:52 浙江
AIGC项目急招后端实习生,运营实习生,UI设计实习生,支持远程实习,想攒攒实习经历的话,欢迎来私聊了解~ (PS:没有经验也没关系,我们都是大厂老司机出来创业的,能够提供专业的指导,后期也能帮你润色简历,直推大厂)
点赞 回复 分享
发布于 2023-08-03 19:17 北京
太猛了
点赞 回复 分享
发布于 2023-08-01 17:21 广东

相关推荐

是第三次面试。全是八股拷打。【面试问题】1. 请先做一下自我介绍。2. 你主要使用哪些编程语言?3. 用 Go 和 Python 分别做过什么?4. 对 C++ 标准库里的容器有了解吗?说说 map 或哈希表的实现。5. 哈希表如何解决冲突?6. 除链地址法外,还有哪些冲突解决方法?7. 开放寻址删除元素时需要注意什么?8. 如何避免哈希表退化成少数长链?9. unordered 系列容器如何避免退化?10. 红黑树具体实现了解多少?11. 如何设计一个既支持快速插入删除,又支持下标索引的容器?12. deque 的大致实现原理是什么?13. 请手写双向链表结构,并实现尾部插入。14. Node** 与 Node* 的区别是什么?15. C++ 智能指针有哪些?各自作用?16. weak_ptr 如何打破循环引用?17. 如何检测代码存在循环引用或内存泄漏?18. 其他语言的垃圾回收策略有了解吗?19. 进程运行时内存布局是怎样的?20. 全局/静态变量位于哪个段?21. 为什么要做内存对齐?22. 多进程间有哪些通信方式?23. 共享内存读写时如何同步?24. 除共享内存、管道、信号外,还有哪些 IPC 方式?25. TCP 连接如何检测对端断开?26. TCP 三次握手、四次挥手过程?27. 游戏为何常用 UDP?需在 UDP 之上做哪些改进?28. KCP 为什么延迟更低?29. UDP 服务端如何维护连接状态?30. Redis 的 zset 怎么实现?31. 跳表原理是什么?32. Redis 集群如何把数据分布到各节点?33. 求数组第 K 大元素有哪些方法?34. 如何用 Redis 实现分布式锁?35. 最长「0 和 1 数量相等」子串如何做?36. 若把 0 换成 -1,求和为 0 的最长子段,有思路吗?37. 在 Linux 源码方面做过哪些学习或开发?38. 还有想补充的项目细节吗?39. 对游戏服务器开发有哪些了解?40. 平时玩哪些游戏?41. 未来职业规划是什么?更倾向游戏还是其他方向?42. 有没有想进一步了解的问题?
校招求职有谈薪空间吗
点赞 评论 收藏
分享
11-01 03:05
门头沟学院 Java
1、挑一个项目介绍一下2、Agent项目是实习项目还是个人项目?有没有上线?3、拷打实习(10min)4、大模型微调,你的训练数据集是如何构建的?数据量有多大?5、在构建数据集的过程中,遇到了哪些挑战?花了多长时间?6、你之前的实习经历偏后端工程,你未来的职业规划更倾向于纯后端开发,还是希望从事与AI/大模型结合的工作?7、详细讲一下Golang中Channel的概念和作用,它是否是并发安全的?8、Channel和传统的锁(Mutex)在实现并发控制时有什么区别?各自的适用场景是什么?9、讲一下GMP模型10、当P的本地队列为空或者不为空时,它会怎么去调度G(协程)?11、Redis支持哪些数据结构12、为什么Redis的速度这么快13、如何实现一个类似淘宝搜索框的实时商品名称模糊搜索功能?14、实时输入联想与输入完成后点击搜索在技术实现上有什么本质区别?15、实时搜索通常使用什么网络协议(如WebSocket)?你了解或有使用过吗?讲一下16、请详细说明微信扫码登录的完整流程和背后发生的原理17、在微服务架构中,服务发现和负载均衡是如何实现的?18、服务注册中心(如Nacos, Consul)是如何工作的?服务实例如何注册和保活(如通过心跳机制)?19、讲一下Agent中的“长短期记忆”20、什么样的信息应该放在长期记忆,什么样的信息放在短期记忆?21、当对话轮数很多,上下文窗口不足时,有哪些处理策略?(如截断、压缩)22、如果要进行记忆压缩,通常有哪些方法?23、了解过Agent的设计范式吗?有哪些?24、你设计的Agent是怎么实现ReAct模式的?详细讲讲25、手撕:实现一个并发任务处理器:给定一个包含100个任务ID的列表,要求控制最大并发数为3,模拟并发调用某个外部接口(如打印ID)
查看24道真题和解析
点赞 评论 收藏
分享
嵌入式的小白:我也遇到过这种,聊的不错的,但就挂了,估计是匹配度不高,有时候觉得不好的,反而面试过了呢
查看5道真题和解析
点赞 评论 收藏
分享
评论
60
319
分享

创作者周榜

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