非科班转码:211化学本→985材料硕→字节后端开发

背景

我推导不出动态规划的状态转移方程,于是我选择贪心算法,不断寻找当前人生阶段的最优解。

笔者本科末流211化学类专业,化工厂的噪声&&毒气&&倒班,让我迫切想要逃离,当时的我以为学术是什么非常高大上的东西,于是考研至某985材料专业,并且在所谓的“国家重点实验室”里。

但是,毕业进高校的时代早已过去,无意义的科研又让我一度陷入迷茫。于是自学java,B站、星球、小林coding、javaguide、面试鸭我都刷过。力扣刷了大概300道。当时觉得,我的每一份努力都是有意义的,我背的八股能用在简历上、面试中。

我的简历整整两页,教育背景部分却只有三行,本硕学校+英语六级(570+)。没有专业课程和绩点,但是写了一堆专业技能,涵盖计算机四大件。没有科研、实习、论文、竞赛,但是写了三个项目。并且我边背八股边修改专业技能,把面试官爱问的直接写上去了。2025年12月开始海投海面,2026年1月面了二十多场(美团、字节、京东、腾讯等等)。

决定转码那时,我凌晨三点可能还在到处找有关转码可行性的帖子,后面我刷了足够多的题,就再也没有那样内耗过了。所以,行动真能战胜焦虑!

现在入职字节一个月了,整理了一下面经。

字节tt一面

一、基础部分(基本熟练吟唱):

1、mysql事务特性、如何实现的、mvcc原理

2、描述一下B+树索引结构

3、mysql两阶段提交过程、目的

二、项目相关:

1、你项目里用到了美团leaf,那你说一下分布式id常见的实现方案(熟练吟唱)

2、项目里分离存储笔记元数据、文本内容的目的 (从性能、扩展性角度解释了一下)

3、rocketmq事务消息的原理(熟练吟唱)

4、rocketmq顺序消息问题:生产者指定哈希Key没问题,但是消费者通过单线程消费性能太低,有什么解决方法吗?(不会。后面发现可以让消费者再次哈希分片到不同内存队列,相同key依然有序)

5、延迟双删基于什么考虑的?

6、同一时间删除了大量key怎么办?(没反应过来。后面发现可以随机化删除时间,类似于缓存雪崩问题。)

7、Zset也属于比较重的数据结构,频繁操作Zset压力过大怎么解决?

8、RAG切片方案有哪些?

9、手撕:

  • 三个线程交替打印1、2、3(秒了,三个线程分别执行三个方法,通过一个flag来标识哪个线程执行)
  • 最长不重复子串的长度 (秒了)

10、如果团队合作时,方案冲突了怎么解决?

反问对我的评价:“基础扎实”

面完后秒约二面

字节tt二面

深挖项目,穿插八股

0、自我介绍

1、挑一个项目从头到尾说

2、你的项目里,如果大量用户请求,有哪些优化方案。 (当时紧张了,就说了一个多级缓存。其实可以从多个角度去说:CDN、nginx、gateway、负载均衡、本地缓存、分布式缓存、并发调下游、分库分表、redis cluster、主从加读写分离、限流降级熔断.......)

3、redis内存不够怎么办?(又紧张了,只说了过期时间,内存淘汰都忘记说了

4、MQ消费失败怎么办、写入多张表怎么保证一致性

5、用Cassandra去存文本内容,那你了解过它的底层原理吗?(还好提前看了LSM树的结构)

6、你项目中流量聚合是在内存中做到,数据丢失怎么办?(有数据对齐服务,满足最终一致性)

7、讨论数据库异地容灾问题,问我北京机房数据怎么同步到上海机房?(没搞懂想问啥,回答直接复制过去,还胡言乱语了一下,说可以通过raft保证一致性。后面发现他可能想听到类似于这样的答案:基于Canal挖掘binlog实时同步MySQL数据到ES。面完后赶紧把这个知识点加在简历上,果然面字节财经的时候问到了mysql主从复制原理)

8、RAG混合检索有什么优点

9、后续若干个项目问题。。。

10、手撕:力扣162. 寻找峰值、说思路(二分法秒了)

11、你对AI coding有什么了解(只说了ai能够生成函数级代码,答得最差的一题,后面被横向两周后挂,大概率就是因为它)

再次反问评价:“非科班能学这么多,感觉你对技术挺有热情”

面完第二天中午约三面

字节tt三面

1、介绍RAG项目(吟唱一半被打断,嫌我太罗嗦了,让我说重点,但我之前就是这么背的,临时总结不出来

2、介绍完项目,面试官对我失去兴趣,直接开始做题:一道原创dp,感觉力扣中等难度级别,类似于力扣的最小花费爬楼梯。二十分钟左右AC。

一周后hr面

字节tt hr面

1、介绍项目以及优化过程(hr面还问项目啊)

2、我看你之前不是计算机相关专业的,为什么考虑转过来?怎么考虑的?考研怎么选择?

3、决定转码也就一年的时间,怎么规划学习的?

4、有没有投递其它岗位(投了腾讯、京东、美团,但是最想去字节),追问为什么?(一顿猛吹。。。)

5、如果offer,到岗时间,实习时长

6、前几轮聊下来对我们的岗位有什么了解吗?

7、职业规划

后续横向对比了两周,挂,立马被推给字节财经

字节财经一面

0、自我介绍

1、说一下java nio原理(不懂,用go的组问我java nio干嘛。。后面发现go的select 、channel和java nio有点像)

2、一万个请求用多少个线程处理比较合适(不懂,说了10个线程)

3、七层网络模型和四层网络模型的区别

4、四次挥手卡在close_wait是为什么(应用层没有调用close方法导致tcp不发送第三次挥手的fin报文)

5、说一下拥塞控制

6、进程和线程的区别?高并发下还能用什么?(说了协程)

7、redis数据类型和应用场景?

8、使用Redis分布式锁会遇到哪些问题?

9、说一下常见设计模式。

手撕:

  • 单例模式,秒了。
  • 两道SQL(一道group by + having过滤,一道topk问题,可以用相关子查询),秒了。
  • 二叉树最近公共祖先(自定义TreeNode,按要求手动构造二叉树),秒了。

10、又问一次对AI coding的了解。

面完秒约二面。

字节财经二面

1、文件分片上传、断点续传怎么做的?

2、混合检索怎么做的,怎么融合多路召回结果,对召回率有什么影响

3、相似度检索的原理(没有了解过)

4、微服务怎么相互调用的?拆分微服务有什么优点和缺点

5、又问一次Cassandra的原理,问lsm树的原理,对比B+树的优缺点(项目写一些奇怪的组件会被连续追问)

6、mysql主从同步原理、同步半同步异步有什么区别。

7、说一下transformer的原理(这不为难我嘛,尝试转移话题,回答:不了解,但是我懂一些agent的原理)

8、那你说agent的原理(说了react模式的原理)

9、第三次问对AI coding的了解.......追问agent skill是什么

10、手撕合并k个有序数组(只刷过合并k升序链表,于是按照类似思路,用最小堆做,十多分钟AC,后面发现用归并排序更简单)

字节财经三面

1、项目为什么要用MQ,线程池也能够做流量削峰

2、限流是怎么做的?限流的redis key是什么?

3、RAG召回率问题,怎么提高的?

4、prompt的结构?召回流程?怎么保存历史消息?

5、项目上线、压测、QPS等问题

6、手撕力扣原题:301. 删除无效的括号(非hot100的hard题,有点复杂,只能说命好,一周前刚好刷到这道题,秒了)

offer

无hr面,大概一周后offer

总结

  • 后端岗确实卡学历,尤其是业务逻辑复杂的岗位,他们认为:学历高=学习能力强=能够快速梳理业务逻辑,大厂一般不卡专业,毕竟在梳理业务逻辑这一块,计算机、通信、材料或者化学专业的人没有本质差别。
  • 北邮计算机的来了,简历上也可能是苍穹外卖+黑马点评这样的经典组合,所以不必焦虑,多刷题多做项目多学习技术方案比啥都强。
  • 学会换位思考,通过刷面经来理解面试官对什么感兴趣。面试官总是倾向于问他熟悉的领域的问题,或者通用的计算机基础问题。所以简历项目的业务逻辑不要太复杂,也不要太冷门。我的一个业务冷门的项目,虽然被我包装成真实项目,但没怎么被问过。而另外两个项目,一个社交笔记项目(业务逻辑就是对笔记的增删改查,但涉及到各种高并发&一致性问题)和一个RAG项目被反复拷打。

全部评论
最近找实习只有字节给面试,面完二面没消息了
1 回复 分享
发布于 昨天 22:49 北京
兄弟太牛逼了
点赞 回复 分享
发布于 昨天 23:11 北京
请问算法是acm形式么
点赞 回复 分享
发布于 昨天 22:44 湖南

相关推荐

牛客62533758...:华为不卡双非,而是卡院校hhhh
点赞 评论 收藏
分享
评论
4
6
分享

创作者周榜

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