第一次凡尔赛,字节跳动 3 面 + 腾讯 6 面一次过,谈谈我的大厂面经
写在开头的闲言碎语
2020 年过去了,对很多人来说,这一年经历了太多太多,可能是十年来记忆里比较浓墨重彩的一笔。过去的一年里,“熬”算是这个阶段我的关键字,确实太多时候就要放弃,好在自己“熬”过去了,在新的 2021 年里,也有个一个非常好的开端,我收获了心仪的 offer。
简单来说,就如标题一样,我今天也想要凡尔赛一次,原来大厂的面试也没有想象中的那么难,字节跳动 3 面+腾讯 6 面,就这么一次性过了,下面就细细聊聊我的大厂面经吧,希望能够给金三银四要面试的朋友提供一些经验。
PART1:字节跳动 3 轮面试场景重现
——字节跳动第一面:
第一面相对来说肯定要简单一些的,所以整个过程中心态是放得比较平稳的,没有太多紧张感,这一轮主要是考察基础,然后会问一些项目相关的问题。
①TCP 相关的基础知识
问题一:请详细描述三次握手和四次挥手的过程(要求熟悉三次握手和四次挥手的机制,并画出状态图)
问题二:四次挥手中 TIME_WAIT 状态存在的目的是什么?(要求画出四次挥手的状态图,接着会引申问题,问到为什么四次挥手是四次不是二次?)
问题三:TCP 是通过什么机制保障可靠性的?(这个问题简单,但要回答得比较全面。需要从四个方面作答,包括 ACK 确认机制、超时重传、滑动窗口以及流量控制,甚至详细讲出流量控制的机制。)
②语言相关的基础知识
字节跳动以 Go 为主,所以尽管是后端岗位,也会问你对 Go 了解多少,对其他语言掌握多少?
Java 语法基础
③网络编程相关基础
问题一:网络 IO 模型有哪些?(5 种网络 I/O 模型,阻塞、非阻塞、I/O 多路复用、信号驱动 IO、异步 I/O。从数据从 I/O 设备到内核态,内核态到进程用户态分别描述这 5 种的区别。)
问题二:I/O 多路复用中 select/poll/epoll 的区别?(从 select 的机制,以及 select 的三个缺点,讲解 epoll 机制,以及 epoll 是如何解决 select 的三个缺点的。还会讲到 epoll 中水平触发和边沿触发的区别。)
④HTTP 相关基础
问题一:客户端访问 url 到服务器,整个过程会经历哪些?(从七层网络模型,HTTP->TCP->IP->链路整个过程讲解报文的产生以及传递的过程)
问题二:描述 HTTPS 和 HTTP 的区别(从端口的区别,以及 HTTPS 是在 SSL 的基础上以及加密等方面说明)
问题三:HTTP 协议的请求报文和响应报文格式(要非常清楚请求报文和响应报文的组成部分,要求在写具体案例。)
问题四:HTTP 的状态码有哪些?(从 2xx,3xx,4xx,5xx 分别举例出常见的 code,面试官会问 301 和 302 的区别,以及 500/503/504 分别在哪些场景出现。)
⑤缓存和数据库的基础知识
问题一:描述一下 redis 有哪些数据结构?(基础的数据结构有 5 种,高级数据结构 4 种。面试官还问了 BloomFilter 的原理以及 Zset 的实现原理,主要讲解跳跃表。)
问题二:MySQL 场景题目(面试官提供场景,要求写出查询 SQL,考察联合语句,如何分页以及复杂语句的优化。)
⑥裸写算法
树的非递归先序遍历。
——字节跳动第二面:
①项目经验
二面的问题基本上都是以个人的项目经验为主,根据项目来提出一系列的问题。流程跟平时面试其他公司没有什么太多差别,面试官会要你先自己介绍自己公司的项目,在介绍的过程中就会根据你说的一些细节进行提问,一般会引申到项目的难度和架构方面,比如要你说出项目中遇到的难度,以及解决方案,再往深问就是有没有更好的解决方案。
分布式项目,考点:分布式事务、分布式一致性;
API 业务,考点:(1)负载均衡、CDN、DNS 等问题;(2)HTTP 相关问题,如描述 HTTP 版本的区别等;
②裸写算法
回行矩阵遍历
——字节跳动第三面:
①项目经验
同样是考察项目经验,但与二面不同的是,三面更注重系统设计这一方面。大致情况就是,要你描述与二面不同的项目经验,问具体详细到问你的项目方案,缺点,改进的地方等。
要求模块化:目前系统如果要做微服务架构,如何进行服务的拆分?拆分的规则是什么?
考察微服务微服务架构相关知识:服务治理(限流、降级、熔断)
②裸写算法
二叉树多个节点的最近公共祖先
PART2:腾讯 6 面场景重现
——腾讯一面:
①针对微服务进行提问:
微服务架构
框架的实现
服务治理
分布式一致性
②日志监控系统:
考察架构、ELK 相关知识,重点要描述 ELK 的一些架构原理,如倒排索引的原理等;
③消息队列:
Kafka 中消息可以被多个消费者消费吗?
选举机制
HW 机制
④数据库和 Redis 相关:
索引的原理
几种事务的区别
数据结构
延时队列如何实现
分布式锁原理
⑤其他开放问题:
开放问题,不过多描述,如项目中遇到的问题,如何解决的?描述生产过程中运行的问题,并描述排查问题。
——腾讯二面(笔试):
考察具体岗位的技术栈语言的基础知识,题目不难,要求基础扎实和广度,文中不过多赘述,大致题目整理到 pdf 文档里。
——腾讯三面+四面(技术组长面):
腾讯的三面和四面都是技术组长来面的,这个阶段相对来说还是比较紧张的,面试内容则主要是聊解题的思路以及项目经验,考察个人对于技术掌握的一个广度,涉及到比较多的架构设计。
项目
开放性题:解题思路、同事之间的协作问题。
负载均衡
算法
ngnix 如何做限流?
四层 LVS 和七层 Ngnix 的区别
微服务架构的设计思路
——腾讯五面+六面(技术总监面):
这两面的面试官应该是技术总监,面试难度应该是这一套流程里最大的,主要考察面试者的两个方面,包括系统设计和架构设计,需要面试者对于技术知识有比较深度的理解和认识。
①针对系统设计提问:
秒杀系统如何设计?分接入层、接口层、消息队列层、逻辑层四个方面讲解,接入层可以做服务治理相关事情,接口层做抢购开关、黑白名单、随机拒绝等处理,逻辑层具体抢购逻辑实现,涉及到 redis 分布式锁以及 DB 和 Redis 的一致性问题。
分布式事务的几种实现。重点讨论了这几种实现的区别,面试官要求我画出基于可靠消息服务的消息队列实现分布式事务架构图,然后对上游服务和下游服务如何保证消息可靠性和一致性。
②针对微服务架构进行提问:
服务拆分的原则
RPC 框架原理
配置管理(etcd)的一致性协议 raft 选举原理
③其他:
服务治理
服务限流算法
服务降级的指标和恢复指标
服务熔断
④开放性问题:
在项目中,你印象中遇到的印象最深的一个难题,如何解决的?
在面试过程中,你觉得面试官问的哪个问题让你印象最深,为什么?
生活中有遇到过什么困难吗?
PART3:我是如何准备面试的?
①准备简历(敲门砖,不会包装简历的程序员只能去外包)
程序员的简历一定要多下一些功夫,尤其是对一些字眼要再三斟酌,如“精通、熟悉、了解”这三者的区别一定要区分清楚,否则就是在给自己挖坑了。当然不会包装,我可以将我的简历给你参考参考,如果还不够,那下面这些简历模板任你挑选:
②了解面试公司,做好功课,知道问什么
对一线互联网大厂的面试点,我也做了以下总结:
阿里巴巴、百度、腾讯
字节跳动、美团、京东
③梳理知识体系,学会举一反三
实际上,梳理知识体系是最简单的事,但很多开发小白总是一头雾水,实际上从第二点的大厂面试点就可以总结梳理出来我们应该要学什么,要掌握什么,通常我的方法是“大厂面试点”+“工作年限”来梳理自己接下来的学习及发展路线图。
之后,就需要根据路线图上的重点去进行有针对性的学习,在学习过程中,学会举一反三,学会写笔记,做总结。
这里我分享我个人的一些笔记内容吧:
Java 开发核心笔记
Redis 学习笔记
SpringBoot 核心技术笔记
④刷面试题
刷题的重要性,我想不用多说。对于应届生或工作年限不长的人来说,刷面试题一方面能够尽可能地快速自己对某个技术点的理解,另一方面在面试时,有一定几率被问到相同或相似题,另外或多或少也能够为自己面试增加一些自信心,可见适当的刷题是很有必要的。
写在最后的总结
最后想说的是,2021 年的金三银四一眨眼也要到了,对于很多人来说是跳槽的好机会,大厂面试远没有我们想的那么困难,摆好心态,做好准备,你也可以的。
另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。
欢迎大家扫码来关注公众号博主,获取文章全部资料,此公众号会持续更新技术干货、不定期分享 Java 进阶面试宝典、Java 核心知识、架构书籍电子版
评论