面试半年靠着这个秋招我终于上岸了,已经入职字节跳动,附上我的面经分享!

前言

本人情况:双非软工,Java后台开发,但是由于后端竞争过于激烈,已转客户端,感谢字节爸爸接收零经验客户端小白,送上面经回馈大众。
长达一年的长跑总算画上圆满的句号了,从2月份疫情开始就投后端实习,但是准备不是太充分,就被各路大神吊打了,6月份找到了国企实习,秋招初期也拿到不少小厂offer,但是我还是想拼一波大厂,最终11月被字节捞起来面试,顺利OC,感谢之前给我帮助的各位大佬,感谢字节爸爸。
现在我也来写面经帮助大家

另外我这里为大家准备了一线大厂面试资料和我原创的超硬核PDF技术文档,以及我为大家精心准备的多套大厂面试题(不断更新中),有需要的朋友点这里备注csdn,自行下载!希望大家都能找到心仪的工作!

一面

  1. 介绍一下自己, 为什么选择出来看看机会

  2. 聊项目, 警报怎么做的, 统一接入监控项怎么做的

  3. 聊项目, 配置中心项目, 问实时配置推送怎么做

  4. 讨论为什么选择所有的组件依赖放在配置中心中控制

  5. 我现在要做一个限流功能, 怎么做?

  6. 这个限流要做成分布式的, 怎么做?

  7. 怎么抢锁?锁怎么释放?

  8. 加了超时之后有没有可能在没有释放的情况下, 被人抢走锁?怎么解决?

  9. 不用 zk 的心跳,可以怎么解决这个问题呢?

  10. 假如这个限流希望做成可配置的, 需要有一个后台管理系统随意对某个 api 配置全局流量, 怎么做?

  11. 某一个业务中现在需要生成全局唯一的递增 ID, 并发量非常大, 怎么做?

  12. 算法题, M*N 横向纵向均递增的矩阵找指定数

  13. 有什么想问我的?

二面

  1. 平时用的工具链和技术栈是什么?

  2. golang 踩过坑吗?

  3. 这段 golang 代码有没有 bug?

  4. Java 中 HashMap 的存储, 冲突, 扩容, 并发访问分别是怎么解决的?

  5. 拉链法中链表过长时变形为红黑树有什么优缺点?

  6. HashMap 的并发不安全体现在哪?

  7. HashMap 在扩容时, 对读写操作有什么特殊处理?

  8. ConcurrentHashMap 是怎么做到并发安全的?

  9. Java 有哪些锁机制, 分别有什么特点?

  10. 知道 CAS 吗? Java 中 CAS 是怎么实现的?

  11. MySQL 的存储引擎用的是什么?为什么选 InnoDB?

  12. MySQL 的聚簇索引和非聚簇索引有什么区别?

  13. B+树和二叉树有什么区别和优劣?

  14. 针对一个场景设计索引,考察的是联合索引与列选择性的知识

  15. 现有一个新的查询场景, 要怎么解决?

  16. 假如要查 A in () AND B in (), 怎么建索引?

  17. 查 A in () AND B in () 时, MySQL 是怎么利用索引的?

  18. 假如查询 A in (), MySQL 是针对 N 个值分别查一次索引, 还是有更好的操作?

  19. 用过 Redis 的哪几种数据结构?ZSET 是怎么实现的?

  20. zrange start, stop, 总长度为 n, 复杂度是多少?

  21. Kafka 的消费者如何做消息去重?

  22. 介绍一下 Kafka 的 ConsumerGroup

  23. Kubernetes 和 Docker 用得怎么样?

  24. 时序型数据库的存储结构是怎么样的?

  25. LSM 树了解吗? 是一种什么存储结构?

  26. 在生产中用过 Cassandra 和 RocksDB 吗? 量有多大?

  27. Cassandra 的墓碑机制是什么 ?

  28. 算法题:牛客题霸上的原题,可以去看看:NC76用两个栈实现队列

三面

  1. 聊项目和工作经验

  2. 用 Kubernetes 的过程中踩过哪些坑?

  3. 考虑一个业务场景: 头条的文章的评论量非常大, 比如说一篇热门文章就有几百万的评论, 设计一个后端服务, 实现评论的时序展示与分页

  4. 假如用 id 翻页的方式, 数据库表如何设计? 索引如何设计?

  5. 假如量很大, 你觉得需要分库分表吗? 怎么分?

  6. 分库分表后怎么查询分页?

  7. 分库分表后怎么保证主键仍然是递增的?

  8. 现在需要支持深分页, 页码直接跳转, 怎么实现?

  9. 瞬时写入量很大可能会打挂存储, 怎么保护?

  10. 断路器内部怎么实现的?

  11. 断路器会造成写入失败, 假如我们不允许写入失败呢?

  12. 算法题: N 场演唱会, 以 [{startTime, endTime}…] 的形式给出, 计算出最多能听几场演唱会。用你最熟悉的语言把这个算法实现

  13. 你用了贪心法, 贪心可能会存在什么问题?

总结

最后我为大家准备了Java架构学习资料,学习技术内容包含有:Spring,Dubbo,MyBatis, RPC, 源码分析,高并发、高性能、分布式,性能优化,微服务 高级架构开发等等。有需要的朋友点这里备注csdn,自行下载,还有Java核心知识点+全套架构师学习资料和视频+一线大厂面试宝典+面试简历模板+阿里美团网易腾讯小米爱奇艺快手哔哩哔哩面试题+Spring源码合集+Java架构实战电子书一起免费分享给大家!

猜你喜欢

转载自blog.csdn.net/weixin_47277170/article/details/111653541