分享美团、字节、腾讯、阿里面经以及面试资料总结,C++多线程面试题

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

  • 最近做过的最有挑战的项目,有哪些难点?

  • 结合项目细聊系统的设计,根据你的设计提出疑问。

  • 你们项目中是如何保证数据一致性的?

  • 代码在执行 SQL 语句时,数据库连接出现了超时异常,但是你不知道这条 SQL 语句在数据库中究竟有没有执行成功,这种情况怎么保证数据的一致性?

  • 你们系统中分布式锁是如何实现的?(当时回答采用 redis 实现,set(key,value,nx,ex,expire))

  • 上面使用 redis 实现分布式锁会存在什么问题?

  • 项目中除了使用 redis 实现分布式锁,还有哪些使用场景?

  • redis 的数据持久化机制?如何保证数据不丢失?当 redis 内存满了以后,内存的淘汰策略?

  • AQS 实现锁的原理?与 synchronize 的区别

  • MySQL 存储引擎的区别?数据库有哪些隔离级别?

  • MySQL 索引的数据结构是什么?为什么选择这种数据结构?

  • B+Tree 和 B-Tree 有什么区别?

  • Reactor 线程模型有哪些?Netty 是如何支持这三种线程模型的?

  • 多路复用器的实现原理?

  • epoll 的实现原理?epoll、poll、select 的区别

  • JVM 如何进行垃圾回收?标记算法有哪些?垃圾回收算法有哪些?

  • CMS 垃圾回收器的原理?

二面

==

  • 最近做过的最有挑战的项目?

  • redis 和 MySQL 的双写一致性问题?你们是如何做的?为什么这样做?其他的做法会存在什么问题?

  • 分布式锁的实现原理

  • 数据库有哪些隔离级别?这几种隔离级别分别解决了什么问题?

  • MySQL 是如何解决不可重复读问题的?

  • MVCC 的实现原理

  • MySQL 的可重复读隔离级别下,存在幻读吗?为什么?

  • 数据库的索引是不是创建得越多越好?为什么?通常创建几个?

  • 一张表中对 a、b、c 三个字段分别建立了索引,现在有一条 SQL 语句:select field1,field2 … from t where a = xx and b=xx and c=xx. 请问这条 SQL 语句会使用到索引吗?如果会,那么会使用到哪个索引?(回答:只会使用其中一个索引,可能是 a,也可能是 b,还有可能是 c,具体使用哪个索引和表中的数据有关)

  • 为什么不会同时使用 a,b,c 三个索引?什么是回表?

  • 聚簇索引和非聚簇索引的区别

  • 如何知道一条 SQL 语句使用了哪些索引?(回答:使用 explain 查看)

  • explain 的结果有哪些列?分别代表什么含义?

  • 如何查看慢 SQL?

  • 在 Spring 事务中执行多条 SQL 语句时,是对应多个数据库连接还是一个数据库连接?(回答:一个连接,多个就无法保证事务了)

  • 既然是一个连接,Spring 在前后执行多条 SQL 时,是如何保证当前线程获取到同一个连接的?(回答:当时没想到 ThreadLocal,面试官引导说,如果是你,会怎么实现。后来回答说存在一个 map,key 是当前线程,value 就是数据库连接,最后灵光一现,想到了 ThreadLocal)

  • ThreadLocal 的实现原理?

  • 使用 ThreadLocal 需要注意哪些问题?(实际上是问 ThreadLocal 内存泄漏的问题)

  • Redis 主从复制的原理

  • MQ 使用过哪些?如何选型?

  • 使用的是什么 RPC 框架?为什么选择它?

  • 线上服务流量猛涨,该如何操作,说下详细过程?新加服务节点也可能会导致服务还没起来,机器就被打爆了,这个时候怎么办?

  • 一个场景题:现在有 1000 万的商家,知道他们的地理位置,当我们进入到 APP 首页时,如何加载出附近的商家?

  • 职业规划?为什么选择在年底前跳槽?

字节

==

三轮技术面试,一轮 HR 面试,每轮技术面试都会至少有一道算法题。

一面

==

  • 一道算法题

  • 聊项目,你们的广告检索引擎是如何设计的?为什么你们的广告检索不使用 ElasticSearch 这样的搜索组件?

  • Java 中的锁有哪些?和 Lock 的区别

  • synchronized 的底层实现原理?

  • AQS 的实现原理?

  • volatile 的作用和实现原理?

  • JVM 的垃圾回收算法

  • GC Roots 有哪些?

  • 简述新生代与老年代的区别?

  • 类的加载过程?什么是双亲委派机制?

  • 线程池的实现原理?线程池满了,再提交任务时会怎么处理?

  • redis 实现分布式锁的原理?redis 的分布式锁有什么问题?lua 脚本熟悉吗?

  • redis 中 key 的过期策略是什么?

  • redis 的持久化机制?AOF 和 RDB 的区别?

  • 什么是缓存击穿、缓存穿透、缓存雪崩?如何处理?

  • MySQL 数据库索引的实现原理?

  • 什么是回表?什么是联合索引?什么是最左前缀匹配原则?

  • MySQL 如何保证高可用?主从复制原理?

  • Explain 关键字的使用。

  • RocketMQ 的实现原理。

  • 注册中心的选型?

  • Zookeeper 作为注册中心的实现原理?

  • Zookeeper 实现分布式锁的原理?

二面

==

  • 一道算法题

  • 详细聊项目经历

  • redis 缓存和数据库数据一致性怎么解决?

  • 分布式系统中,分布式事务怎么解决?(回答:RocketMQ 的事务消息)

  • RocketMQ 事务消息的实现原理?你们的项目中是如何通过 RocketMQ 来保证数据一致性

  • MySQL 为什么使用 B+树来作索引,对比 B 树它的优点和缺点是什么?

  • 什么是覆盖索引?

  • MySQL 中事务的隔离级别?

  • SQL 的优化经验?

  • redis 持久化的机制?如何保证数据不丢失?

  • redis 的内存淘汰策略?key 的过期策略?

  • RocketMQ 如何保证数据的可靠传输(数据不丢失)?

  • RocketMQ 中现在堆积了大量消息,该怎么处理?

  • Netty 的线程模型?主从多线程模型下,线程是如何分工的?

  • 线程池的实现原理是什么?如何设置线程池的参数?

  • 对于 CPU 密集型的系统,为什么线程个数设置为 CPU 核数+1?为什么要+1?

  • 对于 IO 密集型的系统,为什么线程个数为 2 倍 CPU 核数?为什么是 2 倍,而不是 3 倍、4 倍等等?

  • RPC 框架的选型?

  • Motan 是如何实现负载均衡的?

  • 下一步的工作计划?为什么?

三面

==

  • 一道算法题

  • 图这种数据结构了解吗?如何判断图中是否有环?

  • 如何找出图中所有的环境?

  • Http 和 Https 的区别?

  • TCP 三次握手和四次挥手?

  • TCP 如何保证可靠传输?

  • BIO、NIO、AIO 的区别?

  • 加密算法知道哪些?什么是对称加密?什么是非对称加密?

  • 如何保证接口的安全性?应该使用什么加密策略?

  • 说下哈希一致性算法?

  • MySQL 索引的数据结构和原理?

  • MySQL 的调优经验

  • 微服务的技术选型?为什么选择 Motan?

  • RPC 调用的原理

腾讯

==

通常是三轮技术面试,一轮 HR 面试,第一轮面试会有一道算法题,有的时候可能是 4 轮技术面试。

一面

==

一面主要是问 Java 基础,常规题,比较见答案。

  • Java 中使用的是值传递还是引用传递?

  • 方法调用时入参是如何传递的?

  • JVM 中有哪些数据区域?

  • List 集合哪些?ArrayList 和 LinkedList 的区别和使用场景?为什么?

  • HashMap 的实现原理?1.7 和 1.8 的区别?

  • HashMap 中的 hash 算法?这样的 hash 算法有什么好处(高低 16 位均参与运算)?如何寻址?

  • 使用 HashMap 会有哪些问题?(1.7 和 1.8 中有什么不同)如何解决?

  • Java 中有哪些线程安全的 Map?

  • ConcurrentHashMap 的实现原理?1.7 和 1.8 的区别?

  • ConcurrentHashMap 如何统计元素的个数?会有什么问题?

  • 什么是 JMM 内存模型?

  • synchronized 的实现原理

  • 线程池的实现原理?有哪些参数,分别是什么含义?

  • 垃圾回收算法。

  • Java 中反射的基本原理?实际项目中是如何使用反射的?

  • 熟悉哪些设计模式?在项目中哪些地方实际使用过?

  • 一道算法题

二面

==

主要聊的是项目,技术问题都是在聊项目的时候带出来的。

  • 最近做过的最有成就感的项目?这个项目中遇到过什么问题?

  • 你们的分布式系统中如何保证数据一致性问题?(回答:利用了 RocketMQ 的事务消息来保证最终一致性,后面大部分时间都在聊 RocketMQ 的实现原理)

  • 客户端请求过来,后端如何防止重复请求,保证幂等?

  • 如何实现分布式锁?

  • redis 实现分布式锁存在什么问题?

  • redis 分布式锁与 lua 脚本?

  • redission 了解过吗?说说它的实现原理?

  • 在项目中为什么使用 RocketMQ?对于 MQ,你们是如何选型的?

  • RocketMQ 的实现原理?消息是如何存储的?

  • 线上出现 MQ 丢失消息?问题可能出现在哪儿?如何保证 MQ 的消息不丢失?

  • 如何保证 RocketMQ 的高可用性?

  • RocketMQ 的事务消息的实现原理?

  • 如何保证消息的顺序性?

  • 如何保证消息不被重复消费?

  • 你们项目中涉及到了转账相关的业务,那怎么保证资金的准确性和安全性?

  • 针对你们的项目设计一个对账系统。

  • 如何保证分布式系统的强一致性?

三面

==

和二面几乎一样,大部分时间聊项目,问题也类似,重复面试题不再赘述

  • 聊项目经验

  • 使用 redis 过程中遇到过什么问题?如何解决热 key 问题?

  • 你们的 redis 使用的那种模式?集群模式和哨兵模式的区别?集群模式和哨兵模式如何保证 redis 集群的高可用?redis 集群的故障转移过程?

  • raft 协议的原理?

  • JVM 调优经验?

  • 什么是三色标记?

  • 数据库与缓存的双写一致性问题?

  • 结合项目,分库分表该如何设计

  • MySQL 的主从复制原理?

  • ConcurrentHashMap 的实现原理?

  • CucurrentHashMap 中 Node 节点是如何设计的?为什么要用 final 和 volatile 修饰 Node 节点的属性?有什么作用?

  • 对个人职业有什么规划?

四面

==

  • 项目经历

  • 一个对象是如何存储在 JVM 中的?

  • 类加载过程,以及方法的执行的过程?

  • JVM 的垃圾回收机制?为什么要区分新生代、老年代?

  • 线上 GC 有问题,如何排查?

  • Spring 的 AOP 的使用场景?AOP 机制有什么好处?

  • 分布式事务问题,CAP 理论?2PC、XA、TCC、MQ 等原理

  • 类似于淘宝这样的系统,你觉得他们的他们是如何实现数据的强一致性的?

总结:心得体会

既然选择这个行业,选择了做一个程序员,也就明白只有不断学习,积累实战经验才有资格往上走,拿高薪,为自己,为父母,为以后的家能有一定的经济保障。

学习时间都是自己挤出来的,短时间或许很难看到效果,一旦坚持下来了,必然会有所改变。不如好好想想自己为什么想进入这个行业,给自己内心一个答案。

面试大厂,最重要的就是夯实的基础,不然面试官随便一问你就凉了;其次会问一些技术原理,还会看你对知识掌握的广度,最重要的还是你的思路,这是面试官比较看重的。

最后,上面这些大厂面试真题都是非常好的学习资料,通过这些面试真题能够看看自己对技术知识掌握的大概情况,从而能够给自己定一个学习方向。包括上面分享到的学习指南,你都可以从学习指南里理顺学习路线,避免低效学习。

大厂Java架构核心笔记(适合中高级程序员阅读):

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
2PC、XA、TCC、MQ 等原理

  • 类似于淘宝这样的系统,你觉得他们的他们是如何实现数据的强一致性的?

总结:心得体会

既然选择这个行业,选择了做一个程序员,也就明白只有不断学习,积累实战经验才有资格往上走,拿高薪,为自己,为父母,为以后的家能有一定的经济保障。

学习时间都是自己挤出来的,短时间或许很难看到效果,一旦坚持下来了,必然会有所改变。不如好好想想自己为什么想进入这个行业,给自己内心一个答案。

面试大厂,最重要的就是夯实的基础,不然面试官随便一问你就凉了;其次会问一些技术原理,还会看你对知识掌握的广度,最重要的还是你的思路,这是面试官比较看重的。

最后,上面这些大厂面试真题都是非常好的学习资料,通过这些面试真题能够看看自己对技术知识掌握的大概情况,从而能够给自己定一个学习方向。包括上面分享到的学习指南,你都可以从学习指南里理顺学习路线,避免低效学习。

大厂Java架构核心笔记(适合中高级程序员阅读):

[外链图片转存中…(img-H4cY4QFL-1713453505865)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-EapILiVI-1713453505865)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 11
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值