首页 >> 大全

2019 年蚂蚁金服、头条、拼多多面经(万字干货)

2023-11-01 大全 27 作者:考证青年

平台:脉脉、、v2

1、ANT

一面

一面就做了一道算法题,要求两小时内完成,给了长度为N的有重复元素的数组,要求输出第10大的数。典型的TopK问题,快排算法搞定。

算法题要注意的是合法性校验、边界条件以及异常的处理。另外,如果要写测试用例,一定要保证测试覆盖场景尽可能全。加上平时刷刷算法题,这种考核应该没问题的。

二面

1. 自我介绍下呗

2. 开源项目贡献过代码么?(Dubbo提过一个打印的bug算么)

3. 目前在部门做什么,业务简单介绍下,内部有哪些系统,作用和交互过程说下

4. Dubbo踩过哪些坑,分别是怎么解决的?(说了异常处理时业务异常捕获的问题,自定义了一个异常拦截器)

5. 开始进入正题,说下你对线程安全的理解(多线程访问同一个对象,如果不需要考虑额外的同步,调用对象的行为就可以获得正确的结果就是线程安全)

6. 事务有哪些特性?(ACID)

7. 怎么理解原子性?

(同一个事务下,多个操作要么成功要么失败,不存在部分成功或者部分失败的情况)

8. 乐观锁和悲观锁的区别?

(悲观锁假定会发生冲突,访问的时候都要先获得锁,保证同一个时刻只有线程获得锁,读读也会阻塞;乐观锁假设不会发生冲突,只有在提交操作的时候检查是否有冲突)

9. 这两种锁在Java和MySQL分别是怎么实现的?

(Java乐观锁通过CAS实现,悲观锁通过实现。mysql乐观锁通过MVCC,也就是版本实现,悲观锁可以通过... for 加上排它锁)

9. 为什么不是线程安全的?

(多线程操作无并发控制,顺便说了在扩容的时候多线程访问时会造成死锁,会形成一个环,不过扩容时多线程操作形成环的问题再JDK1.8已经解决,但多线程下使用还会有一些其他问题比如数据丢失,所以多线程下不应该使用,而应该使用)

10. 怎么让变得线程安全?

(的方法包装一个线程安全的Map,或者直接用)

11. 两者的区别是什么?

(前者直接在put和get方法加了同步,后者采用了分段锁以及CAS支持更高的并发)

12 .jdk1.8对做了哪些优化?

(插入的时候如果数组元素使用了红黑树,取消了分段锁设计,替代了Lock锁)

13. 为什么这样优化?

(避免冲突严重时链表多长,提高查询效率,时间复杂度从O(N)提高到O(logN))

14. redis主从机制了解么?怎么实现的?

15. 有过GC调优的经历么?(有点虚,答得不是很好)

16. 有什么想问的么?

三面

1. 简单自我介绍下

2. 监控系统怎么做的,分为哪些模块,模块之间怎么交互的?用的什么数据库?(MySQL)使用什么存储引擎

3. 为什么使用?

(支持事务、聚簇索引、MVCC)

4. 订单表有做拆分么,怎么拆的?

(垂直拆分和水平拆分)

5. 水平拆分后查询过程描述下

6. 如果落到某个分片的数据很大怎么办?

(按照某种规则,比如哈希取模、range,将单张表拆分为多张表)

7. 哈希取模会有什么问题么?

(有的,数据分布不均,扩容缩容相对复杂 )

8. 分库分表后怎么解决读写压力?

(一主多从、多主多从)

9. 拆分后主键怎么保证惟一?

(UUID、算法)

10. 生成的ID是全局递增唯一么?

(不是,只是全局唯一,单机递增)

11. 怎么实现全局递增的唯一ID?

(讲了TDDL的一次取一批ID,然后再本地慢慢分配的做法)

12. Mysql的索引结构说下(说了B+树,B+树可以对叶子结点顺序查找,因为叶子结点存放了数据结点且有序)

13. 主键索引和普通索引的区别(主键索引的叶子结点存放了整行记录,普通索引的叶子结点存放了主键ID,查询的时候需要做一次回表查询)一定要回表查询么?

(不一定,当查询的字段刚好是索引的字段或者索引的一部分,就可以不用回表,这也是索引覆盖的原理)

14. 你们系统目前的瓶颈在哪里?

15. 你打算怎么优化?简要说下你的优化思路

16. 有什么想问我么?

四面

1. 介绍下自己

2. 为什么要做逆向?

3. 怎么理解微服务?

4. 服务治理怎么实现的?

(说了限流、压测、监控等模块的实现)

5. 这个不是中间件做的事么,为什么你们部门做?

(当时没有单独的中间件团队,微服务刚搞不久,需要进行监控和性能优化)

6. 说说的生命周期吧

7. 说说GC的过程(说了young gc和full gc的触发条件和回收过程以及对象创建的过程)

8. CMS GC有什么问题?

(并发清除算法,浮动垃圾,短暂停顿)

9. 怎么避免产生浮动垃圾?

(记得有个VM参数设置可以让扫描新生代之前进行一次young gc,但是因为gc是虚拟机自动调度的,所以不保证一定执行。但是还有参数可以让虚拟机强制执行一次young gc)

10. 强制young gc会有什么问题?

(STW停顿时间变长)

11. 知道G1么?

(了解一点 )

12. 回收过程是怎么样的?

(young gc、并发阶段、混合阶段、full gc,说了 Set)

13. 你提到的 Set底层是怎么实现的?

14. 有什么想问的么?

五面

五面是HRBP面的,和我提前预约了时间,主要聊了之前在蚂蚁的实习经历、部门在做的事情、职业发展、福利待遇等。阿里面试官确实是具有一票否决权的,很看重你的价值观是否match,一般都比较喜欢皮实的候选人。HR面一定要诚实,不要说谎,只要你说谎HR都会去证实,直接cut了。

1. 之前蚂蚁实习三个月怎么不留下来?

2. 实习的时候主管是谁?

3. 实习做了哪些事情?

4. 你对技术怎么看?平时使用什么技术栈?

(阿里HR真的是既当爹又当妈,)

5. 最近有在研究什么东西么

6. 你对SRE怎么看

7. 对待遇有什么预期么

最后HR还对我说目前稳定性保障部挺缺人的,希望我尽快回复。

小结

蚂蚁面试比较重视基础,所以Java那些基本功一定要扎实。蚂蚁的工作环境还是挺赞的,因为我面的是稳定性保障部门,还有许多单独的小组,什么三年1班,很有青春的感觉。面试官基本水平都比较高,基本都P7以上,除了基础还问了不少架构设计方面的问题,收获还是挺大的。

2、PDD

面试前

面完蚂蚁后,早就听闻拼多多这个独角兽,决定也去面一把。首先我在脉脉找了一个拼多多的HR,加了微信聊了下,发了简历便开始我的拼多多面试之旅。这里要非常感谢拼多多HR小姐姐,从面试内推到offer确认一直都在帮我,人真的很nice。

一面

1. 为啥蚂蚁只待了三个月?没转正?

2. Java中的、解释下?

(红黑树,有序,无序,数组+链表)

3. 查询写入的时间复杂度多少?

(O(logN))

4. 多线程有什么问题?

(线程安全,死锁)

5. 怎么解决?

( jdk1.8用了 + CAS,扩容的时候通过CAS检查是否有修改,是则重试)

6. 重试会有什么问题么?

(CAS( And Swap)是比较和交换,不会导致线程阻塞,但是因为重试是通过自旋实现的,所以仍然会占用CPU时间,还有ABA的问题)怎么解决?

(超时,限定自旋的次数,ABA可以通过原理变量ce解决,原理利用版本号进行比较)超过重试次数如果仍然失败怎么办?

(互斥锁)

7. CAS和有什么区别?都用不行么?

(CAS是乐观锁,不需要阻塞,硬件级别实现的原子性;会阻塞,JVM级别实现的原子性。使用场景不同,线程冲突严重时CAS会造成CPU压力过大,导致吞吐量下降,的原理是先自旋然后阻塞,线程冲突严重仍然有较高的吞吐量,因为线程都被阻塞了,不会占用CPU )

8. 如果要保证线程安全怎么办?

()

9. 怎么实现线程安全的?

(分段锁)

10. get需要加锁么,为什么?

(不用,关键字)

11. 的作用是什么?

(保证内存可见性)

12. 底层怎么实现的?

(说了主内存和工作内存,读写内存屏障,-,并在纸上画了线程交互图)

13. 在多核CPU下,可见性怎么保证?

(思考了一会,总线嗅探技术)

14. 聊项目,系统之间是怎么交互的?

15. 系统并发多少,怎么优化?

16. 给我一张纸,画了一个九方格,都填了数字,给一个MN矩阵,从1开始逆时针打印这MN个数,要求时间复杂度尽可能低(内心OS:之前貌似碰到过这题,最优解是怎么实现来着)思考中。

17. 可以先说下你的思路(想起来了,说了什么时候要变换方向的条件,向右、向下、向左、向上,依此循环)

18. 有什么想问我的?

二面

1. 自我介绍下

2. 手上还有其他offer么?

(拿了蚂蚁的offer)

3. 部门组织结构是怎样的?

(这轮不是技术面么,不过还是老老实实说了)

4. 系统有哪些模块,每个模块用了哪些技术,数据怎么流转的?

(面试官有点秃顶,一看级别就很高)给了我一张纸,我在上面简单画了下系统之间的流转情况

5. 链路追踪的信息是怎么传递的?

(的,说了Span的结构: + )

6. 怎么保证唯一性?

(UUID,说了下内部的定制改动)

7. 是在什么维度传递的?

(线程)

8. Dubbo的远程调用怎么实现的?

(讲了读取配置、拼装url、创建、服务导出、服务注册以及消费者通过动态代理、、获取列表、负载均衡等过程(哗啦啦讲了10多分钟),我可以喝口水么)

9. 的单例是怎么实现的?

(单例注册表)

10. 为什么要单独实现一个服务治理框架?

(说了下内部刚搞微服务不久,主要对服务进行一些监控和性能优化)

11. 谁主导的?内部还在使用么?

12. 逆向有想过怎么做成通用么?

13. 有什么想问的么?

三面

二面老大面完后就直接HR面了,主要问了些职业发展、是否有其他offer、以及入职意向等问题,顺便说了下公司的福利待遇等,都比较常规啦。不过要说的是手上有其他offer或者大厂经历会有一定加分。

小结

拼多多的面试流程就简单许多,毕竟是一个成立三年多的公司。面试难度中规中矩,只要基础扎实应该不是问题。但不得不说工作强度很大,开始面试前HR就提前和我确认能否接受这样强度的工作,想来的老铁还是要做好准备

3、字节跳动

面试前

头条的面试是三家里最专业的,每次面试前有专门的HR和你约时间,确定OK后再进行面试。每次都是通过视频面试,因为都是之前都是电话面或现场面,所以视频面试还是有点不自然。也有人觉得视频面试体验很赞,当然萝卜青菜各有所爱。最坑的二面的时候对方面试官的网络老是掉线,最后很冤枉的挂了(当然有一些点答得不好也是原因之一)。所以还是有点遗憾的。

一面

1. 先自我介绍下

2. 聊项目,逆向系统是什么意思

3. 聊项目,逆向系统用了哪些技术

4. 线程池的线程数怎么确定?

5. 如果是IO操作为主怎么确定?

6. 如果计算型操作又怎么确定?

7. Redis熟悉么,了解哪些数据结构?(说了zset) zset底层怎么实现的?(跳表)

8. 跳表的查询过程是怎么样的,查询和插入的时间复杂度?(说了先从第一层查找,不满足就下沉到第二层找,因为每一层都是有序的,写入和插入的时间复杂度都是O(logN))

9 红黑树了解么,时间复杂度?(说了是N叉平衡树,O(logN))

10. 既然两个数据结构时间复杂度都是O(logN),zset为什么不用红黑树(跳表实现简单,踩坑成本低,红黑树每次插入都要通过旋转以维持平衡,实现复杂)

11. 点了点头,说下Dubbo的原理?(说了服务注册与发布以及消费者调用的过程)

12. 踩过什么坑没有?

(说了dubbo异常处理的和打印的问题)

13. CAS了解么?

(说了CAS的实现)还了解其他同步机制么?

(说了以及两者的区别,一个乐观锁,一个悲观锁)

14. 那我们做一道题吧,数组A,2*n个元素,n个奇数、n个偶数,设计一个算法,使得数组奇数下标位置放置的都是奇数,偶数下标位置放置的都是偶数

15. 先说下你的思路(从0下标开始遍历,如果是奇数下标判断该元素是否奇数,是则跳过,否则从该位置寻找下一个奇数)

16. 下一个奇数?怎么找?

17. 有思路么?

(仍然是先遍历一次数组,并对下标进行判断,如果下标属性和该位置元素不匹配从当前下标的下一个遍历数组元素,然后替换)

18. 你这样时间复杂度有点高,如果要求O(N)要怎么做(思考一会,答道“定义两个指针,分别从下标0和1开始遍历,遇见奇数位是是偶数和偶数位是奇数就停下,交换内容”)

19. 时间差不多了,先到这吧。

20. 你有什么想问我的?

二面

1. 面试官和蔼很多,你先介绍下自己吧

2. 你对服务治理怎么理解的?

3. 项目中的限流怎么实现的?

(Guava ,令牌桶算法)

4. 具体怎么实现的?

(要点是固定速率且令牌数有限)

5. 如果突然很多线程同时请求令牌,有什么问题?

(导致很多请求积压,线程阻塞)

6. 怎么解决呢?

(可以把积压的请求放到消息队列,然后异步处理)

7. 如果不用消息队列怎么解决?

(说了预消费的策略)

8. 分布式追踪的上下文是怎么存储和传递的?

( + ,当前节点的作为下个节点的父)

9. Dubbo的是怎么传递的?

()主线程的怎么传递到线程池?

(说了先在主线程通过的get方法拿到上下文信息,在线程池创建新的并把之前获取的上下文信息设置到中。这里要注意的线程池创建的要在中手动,不然会有内存泄漏的问题)

10. 你说的内存泄漏具体是怎么产生的?

(说了的结构,主要分两种场景:主线程仍然对有引用和主线程不存在对的引用。第一种场景因为主线程仍然在运行,所以还是有对的引用,那么变量的引用和value是不会被回收的。

第二种场景虽然主线程不存在对的引用,且该引用是弱引用,所以会在gc的时候被回收,但是对用的value不是弱引用,不会被内存回收,仍然会造成内存泄漏)

11. 线程池的线程是不是必须手动才可以回收value?

(是的,因为线程池的核心线程是一直存在的,如果不清理,那么核心线程的变量会一直持有变量)

12. 那你说的内存泄漏是指主线程还是线程池?

(主线程 )

13. 可是主线程不是都退出了,引用的对象不应该会主动回收么?

(面试官和内存泄漏杠上了),沉默了一会。

14. 那你说下不同用户登录的信息怎么保证线程安全的?

(刚才解释的有点懵逼,一下没反应过来,居然回答成锁了。大脑有点晕了,此时已经一个小时过去了,感觉情况不妙。)

15. 这个直接用不就可以么,你见过有锁实现的代码么?

(有点晕菜。)

16. 我们聊聊mysql吧,说下索引结构(说了B+树)

17. 为什么使用B+树?

( 说了查询效率高,O(logN),可以充分利用磁盘预读的特性,多叉树,深度小,叶子结点有序且存储数据)

18. 什么是索引覆盖?

19. Java为什么要设计双亲委派模型?

20. 什么时候需要自定义类加载器?

21. 我们做一道题吧,手写一个对象池

22. 有什么想问我的么?

(感觉我很多点都没答好,是不是挂了(结果真的是) )

小结

头条的面试确实很专业,每次面试官会提前给你发一个视频链接,然后准点开始面试,而且考察的点都比较全。

面试官都有一个特点,会抓住一个值得深入的点或者你没说清楚的点深入下去直到你把这个点讲清楚,不然面试官会觉得你并没有真正理解。二面面试官给了我一点建议,研究技术的时候一定要去研究产生的背景,弄明白在什么场景解决什么特定的问题,其实很多技术内部都是相通的。很诚恳,还是很感谢这位面试官大大。

总结

从年前开始面试到头条面完大概一个多月的时间,真的有点身心俱疲的感觉。最后拿到了拼多多、蚂蚁的offer,还是蛮幸运的。头条的面试对我帮助很大,再次感谢面试官对我的诚恳建议,以及拼多多的HR对我的啰嗦的问题详细解答。

这里要说的是面试前要做好两件事:简历和自我介绍,简历要好好回顾下自己做的一些项目,然后挑几个亮点项目。自我介绍基本每轮面试都有,所以最好提前自己练习下,想好要讲哪些东西,分别怎么讲。

那些年看过的书:

《 Java》、《现代操作系统》、《TCP/IP详解:卷一》、《代码整洁之道》、《重构》、《Java程序性能优化》、《实战》、《》、《高性能MySQL》、《亿级网站架构核心技术》、《可伸缩服务架构》、《Java编程思想》

说实话这些书很多只看了一部分,我通常会带着问题看书,不然看着看着就睡着了,简直是催眠良药。

本文作者是未来小娃,欢迎关注作者博客 以及订阅号技术视点。

欢迎转发、点赞

关于我们

最火推荐

小编推荐

联系我们


版权声明:本站内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 88@qq.com 举报,一经查实,本站将立刻删除。备案号:桂ICP备2021009421号
Powered By Z-BlogPHP.
复制成功
微信号:
我知道了