2022年五⾯蚂蚁、三⾯拼多多、字节跳动最终拿offer⼊职拼多
多
写在2022年初的蚂蚁、头条、拼多多的⾯试总结
⽂章有点长,请耐⼼看完,绝对有收获!不想听我BB直接进⼊⾯试分享:
准备过程
华清远见嵌入式人工智能蚂蚁⾦服⾯试分享
拼多多⾯试分享
字节跳动⾯试分享
总结
说起来开始进⾏⾯试是年前倒数第⼆周,上午9点,我还在去公司的公交上,突然收到蚂蚁的⾯试电话,其实算不上真正的⾯试。⾯试官只是和我聊了下他们在做的事情(主要是做双⼗⼀这⾥⼤促的稳定性保障,偏中间件吧),说的很详细,然后和我沟通了下是否有兴趣,我表⽰有兴趣,后⾯就收到正式⾯试
的通知,最后没选择去蚂蚁表⽰抱歉。
当时我⾃⼰也准备出去看看机会,顺便看看⾃⼰的实⼒。当时我其实挺纠结的,⼀⽅⾯现在部门也正需要我,还是可以有⼀番作为的,另⼀⽅⾯觉得近⼀年来进步缓慢,没有以前飞速进步的成就感了,⽽且业务和技术偏于稳定,加上⾃⼰也属于那种⽐较懒散的⼈,⾻⼦⾥还是希望能够突破现状,持续在技术上有所精进。
进⼊正题,先后进⾏了蚂蚁、拼多多和字节跳动的⾯试。
准备过程
先说说我⾃⼰的情况,我2016先在蚂蚁实习了将近三个⽉,然后去了我现在的⽼东家,三年多⼯作经验,可以说毕业后就⼀直⽼⽼实实在⽼东家打怪升级,虽说有蚂蚁的实习经历,但是因为时间太短,还是有点虚的。所以⾯试官看到我简历第⼀个问题绝对是这样的。
“哇,你在蚂蚁待过,不错啊”,⾯试官笑嘻嘻地问到。“是的,还好”,我说。“为啥才三个⽉?”,⾯试官脸⾊⼀沉问到。“哗啦啦解释⼀通。。。”,我解释道。“哦,原来如此,那我们开始⾯试吧”,⾯试官⼀本正经说到。
,早知道不写蚂蚁的实习经历了,后⾯仔细⼀想,当初写上蚂蚁不就给简历加点料嘛。
⾔归正传,准备过程其实很早开始了(当然这不是说我⼯作时⽼想着跳槽,因为我明⽩现在的⽼东家并不是终点,我还需要不断提升),具体可追溯到从蚂蚁离职的时候,当时出来也⾯了很多公司,没啥⼤公司,⾯了⼤概5家公司,都拿到offer了。
⼯作之余常常会去额外研究⾃⼰感兴趣的技术以及⼯作⽤到的技术,⼒求把原理搞明⽩,并且会⾃⼰实践⼀把。此外,买了N多书,基本有时间就会去看,补补基础,什么操作系统、数据结构与算法、MySQL、JDK之类的源码,基本都好好温习了(⽂末会列⼀下⾃⼰看过的书和⼀些好的资料)。我深知基础就像“⽊桶效应”的短板,决定了能装多少⽔。
此外,在正式决定看机会之前,我给⾃⼰列了⼀个提纲,主要包括Java要掌握的核⼼要点,有不懂的就查资料搞懂。我给⾃⼰定位还是Java⼯程师,所以Java体系是⼀定要做到⼼中有数的,很多东西没有常年的积累⾯试的时候很容易露馅,学习要对得起⾃⼰,不要骗⼈。
剩下的就是平台和内推了,除了蚂蚁,头条和拼多多都是⼈内推的,感谢蚂蚁⾯试官对我的欣赏,以后说不定会去蚂蚁咯。
平台:脉脉、GitHub、v2
蚂蚁⾦服(五⾯)
⼀⾯
⼀⾯就做了⼀道算法题,要求两⼩时内完成,给了长度为N的有重复元素的数组,要求输出第10⼤的数。典型的TopK问题,快排算法搞定。
算法题要注意的是合法性校验、边界条件以及异常的处理。另外,如果要写测试⽤例,⼀定要保证测试覆盖场景尽可能全。加上平时刷刷算法题,这种考核应该没问题的。
⼆⾯
1. ⾃我介绍下呗
2. 开源项⽬贡献过代码么?
3. ⽬前该部门做什么,业务简单介绍下,内部有哪些系统,作⽤和交互过程说下
4. Dubbo踩过哪些坑,分别是怎么解决的?
5. 开始进⼊正题,说下你对线程安全的理解
6. 事务有哪些特性?
7. 怎么理解原⼦性?
8. 乐观锁和悲观锁的区别?
9. 这两种锁在Java和MySQL分别是怎么实现的?
10. HashMap为什么不是线程安全的?
11. 怎么让HashMap变得线程安全?
12. Collections的synchronize两者的区别是什么?
13. jdk1.8对ConcurrentHashMap做了哪些优化?
14. redis主从机制了解么?怎么实现的?
15. 有过GC调优的经历么?
16. 有什么想问的么?
三⾯
1. 简单⾃我介绍下
openssl参数详解2. 监控系统怎么做的,分为哪些模块,模块之间怎么交互的?⽤的什么数据库?
3. 使⽤什么存储引擎,为什么使⽤InnnoDB?
4. 订单表有做拆分么,怎么拆的?
5. ⽔平拆分后查询过程描述下
6. 如果落到某个分⽚的数据很⼤怎么办?
7. 哈希取模会有什么问题么?
8. 分库分表后怎么解决读写压⼒?
9. 拆分后主键怎么保证惟⼀?
10. Snowflake⽣成的ID是全局递增唯⼀么?
11. 怎么实现全局递增的唯⼀ID?
12. Mysql的索引结构说下
13. 主键索引和普通索引的区别?
14. 你们系统⽬前的瓶颈在哪⾥?
15. 你打算怎么优化?简要说下你的优化思路
mysql面试题库16. 有什么想问我么?
四⾯
1. 介绍下⾃⼰
2. 为什么要做逆向?
3. 怎么理解微服务?
4. 服务治理怎么实现的?
5. 这个不是中间件做的事么,为什么你们部门做?
6. 说说Spring的⽣命周期吧
7. 说说GC的过程
8. CMS GC有什么问题?
9. 怎么避免产⽣浮动垃圾?
10. 强制young gc会有什么问题?
11. 知道G1么?
12. 回收过程是怎么样的?
13. 你提到的Remember Set底层是怎么实现的?
14. 有什么想问的么?
五⾯
五⾯是HRBP⾯的,和我提前预约了时间,主要聊了之前在蚂蚁的实习经历、部门在做的事情、职业发展、福利待遇等。阿⾥⾯试官确实是具有⼀票否决权的,很看重你的价值观是否match,⼀般都⽐较喜欢⽪实的候选⼈。HR⾯⼀定要诚实,不要说谎,只要你说谎HR都会去证实,直接cut了。
1. 之前蚂蚁实习三个⽉怎么不留下来?
2. 实习的时候主管是谁?
scanf运用举例3. 实习做了哪些事情?
4. 你对技术怎么看?平时使⽤什么技术栈?
5. 最近有在研究什么东西么
6. 你对SRE怎么看
7. 对待遇有什么预期么
最后HR还对我说⽬前稳定性保障部挺缺⼈的,希望我尽快回复。
⼩结
蚂蚁⾯试⽐较重视基础,所以Java那些基本功⼀定要扎实。蚂蚁的⼯作环境还是挺赞的,因为我⾯的是稳定性保障部门,还有许多单独的⼩组,什么三年1班,很有青春的感觉。⾯试官基本⽔平都⽐较⾼,基本都P7以上,除了基础还问了不少架构设计⽅⾯的问题,收获还是挺⼤的。
拼多多(三⾯)
⾯试前
⾯完蚂蚁后,早就听闻拼多多这个独⾓兽,决定也去⾯⼀把。⾸先我在脉脉了⼀个拼多多的HR,加
了聊了下,发了简历便开始我的拼多多⾯试之旅。这⾥要⾮常感谢拼多多HR⼩,从⾯试内推到offer确认⼀直都在帮我,⼈真的很nice。
⼀⾯
1. 为啥蚂蚁只待了三个⽉?没转正?
2. Java中的HashMap、TreeMap解释下?
3. TreeMap查询写⼊的时间复杂度多少?
4. HashMap多线程有什么问题?
5. CAS和synchronize有什么区别?都⽤synchronize不⾏么?
6. 如果要保证线程安全怎么办?(ConcurrentHashMap)
7. ConcurrentHashMap怎么实现线程安全的?
8. get需要加锁么,为什么?
9. volatile的作⽤是什么?
10. 底层怎么实现的?
11. 在多核CPU下,可见性怎么保证?
12. 聊项⽬,系统之间是怎么交互的?
13. 系统并发多少,怎么优化?
14. 给我⼀张纸,画了⼀个九⽅格,都填了数字,给⼀个MN矩阵,从1开始逆时针打印这MN个数,要求时间复杂度尽可能低
15. 可以先说下你的思路(想起来了,说了什么时候要变换⽅向的条件,向右、向下、向左、向上,依此循环)
16. 有什么想问我的?
⼆⾯
1. ⾃我介绍下
2. ⼿上还有其他offer么?
3. 部门组织结构是怎样的?
4. 系统有哪些模块,每个模块⽤了哪些技术,数据怎么流转的?
5. 链路追踪的信息是怎么传递的?
intellij idea怎么删除项目6. SpanId怎么保证唯⼀性?
7. RpcContext是在什么维度传递的?
8. Dubbo的远程调⽤怎么实现的?
9. Spring的单例是怎么实现的?
10. 为什么要单独实现⼀个服务治理框架?
11. 谁主导的?内部还在使⽤么?
12. 逆向有想过怎么做成通⽤么?
13. 有什么想问的么?
三⾯
⼆⾯⽼⼤⾯完后就直接HR⾯了,主要问了些职业发展、是否有其他offer、以及⼊职意向等问题,顺便说了下公司的福利待遇等,都⽐较常规啦。不过要说的是⼿上有其他offer或者⼤⼚经历会有⼀定加分。
⼩结
拼多多的⾯试流程就简单许多,毕竟是⼀个成⽴三年多的公司。⾯试难度中规中矩,只要基础扎实应该不是问题。但不得不说⼯作强度很⼤,开始⾯试前HR就提前和我确认能否接受这样强度的⼯作,想来的⽼铁还是要做好准备
字节跳动
⾯试前
头条的⾯试是三家⾥最专业的,每次⾯试前有专门的HR和你约时间,确定OK后再进⾏⾯试。每次都是通过视频⾯试,因为都是之前都是电话⾯或现场⾯,所以视频⾯试还是有点不⾃然。也有⼈觉得视频⾯试体验很赞,当然萝⼘青菜各有所爱。最坑的⼆⾯的时候对⽅⾯试官的⽹络⽼是掉线,最后很冤枉的挂了(当然有⼀些点答得不好也是原因之⼀)。所以还是有点遗憾的。
⼀⾯
1. 先⾃我介绍下
mariadb修改用户密码2. 聊项⽬,逆向系统是什么意思
3. 聊项⽬,逆向系统⽤了哪些技术
4. 线程池的线程数怎么确定?
5. 如果是IO操作为主怎么确定?
6. 如果计算型操作⼜怎么确定?
7. Redis熟悉么,了解哪些数据结构?
8. 跳表的查询过程是怎么样的,查询和插⼊的时间复杂度?
9. 红⿊树了解么,时间复杂度?
10. 既然两个数据结构时间复杂度都是O(logN),zset为什么不⽤红⿊树
11. 点了点头,说下Dubbo的原理?
12. CAS了解么?
13. 那我们做⼀道题吧,数组A,2*n个元素,n个奇数、n个偶数,设计⼀个算法,使得数组奇数下标位置放置的都是奇数,偶数下标位置
放置的都是偶数
14. 先说下你的思路
15. 下⼀个奇数?怎么?
16. 有思路么?
17. 你这样时间复杂度有点⾼,如果要求O(N)要怎么做
18. 时间差不多了,先到这吧。你有什么想问我的?
⼆⾯
1. ⾯试官和蔼很多,你先介绍下⾃⼰吧
2. 你对服务治理怎么理解的?
3. 项⽬中的限流怎么实现的?
4. 具体怎么实现的?
5. 如果突然很多线程同时请求令牌,有什么问题?
6. 怎么解决呢?
7. 如果不⽤消息队列怎么解决?
8. 分布式追踪的上下⽂是怎么存储和传递的?
9. Dubbo的RpcContext是怎么传递的?
10. 你说的内存泄漏具体是怎么产⽣的?
11. 线程池的线程是不是必须⼿动remove才可以回收value?
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论