爱游戏官网
Mou Mou Jidian Generator
发电机维修 发电机回收
发电机出售 发电机租赁
客户统一服务热线

060-837933773
14817097129

4进口发电机组
您的位置: 主页 > 产品中心 > 进口发电机组 >
2019 年蚂蚁金服、头条、拼多多面经(万字干货)

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

本文摘要:文章有点长,请耐心看完,绝对有收获!不想听我BB直接进入面试分享:准备历程蚂蚁金服面试分享拼多多面试分享字节跳动面试分享总结说起来开始举行面试是年前倒数第二周,上午9点,我还在去公司的公交上,突然收到蚂蚁的面试电话,其实算不上真正的面试。面试官只是和我聊了下他们在做的事情(主要是做双十一这里大促的稳定性保障,偏中间件吧),说的很详细,然后和我相同了下是否有兴趣,我表现有兴趣,后面就收到正式面试的通知,最后没选择去蚂蚁表现歉仄。

爱游戏官网

文章有点长,请耐心看完,绝对有收获!不想听我BB直接进入面试分享:准备历程蚂蚁金服面试分享拼多多面试分享字节跳动面试分享总结说起来开始举行面试是年前倒数第二周,上午9点,我还在去公司的公交上,突然收到蚂蚁的面试电话,其实算不上真正的面试。面试官只是和我聊了下他们在做的事情(主要是做双十一这里大促的稳定性保障,偏中间件吧),说的很详细,然后和我相同了下是否有兴趣,我表现有兴趣,后面就收到正式面试的通知,最后没选择去蚂蚁表现歉仄。其时我自己也准备出去看看时机,顺便看看自己的实力。

其时我其实挺纠结的,一方面现在部门也正需要我,还是可以有一番作为的,另一方面以为近一年来进步缓慢,没有以前飞速进步的成就感了,而且业务和技术偏于稳定,加上自己也属于那种比力懒散的人,骨子里还是希望能够突破现状,连续在技术上有所精进。在开始正式的总结之前,还是希望列位同仁能否听我继续发泄一会,抱拳!我掀开自己2018年头立的flag,以为甚是内疚。其中就有一条是保持一周写一篇博客,怎样中间因为种种原因没能坚持下去。

细细想来,主要是自己没能真正静下来心认真投入到技术的研究和学习,那么为什么会这样?说白了还是因为没有确定目的或者目的不明确,没有目的或者目的不明确都可能导致行动的失败。那么问题来了,目的是啥?就我而言,短期目的是深入研究某一项技术,好比最近在研究mysql,那么深入研究一定要动手实践而且有所产出,这就够了么?还需要我们能够闻一知十,联合实际开发场景想一想日常开发要注意什么,这中间有没有什么坑?可以看出,要进步真的不是一件简朴的事,这种反人类的行为需要我们克服自我的弱点,逐渐形成习惯。真正牛逼的人,从不以为认真学习是一件何等难的事,因为这已经形成了他的习惯,就和早上起床刷牙洗脸那么自然简朴。扯了那么多,开始进入正题,先后举行了蚂蚁、拼多多和字节跳动的面试。

先说说我自己的情况,我2016先在蚂蚁实习了快要三个月,然后去了我现在的老东家,2.5年事情履历,可以说结业后就一直老老实实在老东家打怪升级,虽说有蚂蚁的实习履历,可是因为时间太短,还是有点虚的。所以面试官看到我简历第一个问题绝对是这样的。“哇,你在蚂蚁待过,不错啊”,面试官笑嘻嘻地问到。

“是的,还好”,我说。“为啥才三个月?”,面试官脸色一沉问到。

“哗啦啦解释一通。”,我解释道。

“哦,原来如此,那我们开始面试吧”,面试官一本正经说到。尼玛,早知道不写蚂蚁的实习履历了,后面仔细一想,当初写上蚂蚁不就给简历加点料嘛。

言归正传,准备历程其实很早开始了(固然这不是说我事情时老想着跳槽,因为我明确现在的老东家并不是终点,我还需要不停提升),详细可追溯到从蚂蚁去职的时候,其时出来也面了许多公司,没啥大公司,面了或许5家公司,都拿到offer了。事情之余经常会去分外研究自己感兴趣的技术以及事情用到的技术,力图把原理搞明确,而且会自己实践一把。此外,买了N多书,基本有时间就会去看,补补基础,什么操作系统、数据结构与算法、MySQL、JDK之类的源码,基本都好好温习了(文末会列一下自己看过的书和一些好的资料)。我深知基础就像“木桶效应”的短板,决议了能装几多水。

此外,在正式决议看时机之前,我给自己列了一个提纲,主要包罗Java要掌握的焦点要点,有不懂的就查资料搞懂。我给自己定位还是Java工程师,所以Java体系是一定要做到心中有数的,许多工具没有常年的积累面试的时候很容易露馅,学习要对得起自己,不要骗人。剩下的就是找平台和内推了,除了蚂蚁,头条和拼多多都是找人内推的,谢谢蚂蚁面试官对我的浏览,以后说不定会去蚂蚁咯。

在分享履历之前,附一张自己面试前准备的脑图,可以关注订阅号「Web项目聚集地」回复「脑图」获取。平台:脉脉、GitHub、v21、ANT FINANCIAL一面一面就做了一道算法题,要求两小时内完成,给了长度为N的有重复元素的数组,要求输出第10大的数。典型的TopK问题,快排算法搞定。

爱游戏官网

算法题要注意的是正当性校验、界限条件以及异常的处置惩罚。另外,如果要写测试用例,一定要保证测试笼罩场景尽可能全。加上平时刷刷算法题,这种考核应该没问题的。二面1. 自我先容下呗2. 开源项目孝敬过代码么?(Dubbo提过一个打印accesslog的bug算么)3. 现在在部门做什么,业务简朴先容下,内部有哪些系统,作用和交互历程说下4. Dubbo踩过哪些坑,划分是怎么解决的?(说了异常处置惩罚时业务异常捕捉的问题,自界说了一个异常拦截器)5. 开始进入正题,说下你对线程宁静的明白(多线程会见同一个工具,如果不需要思量分外的同步,挪用工具的行为就可以获得正确的效果就是线程宁静)6. 事务有哪些特性?(ACID)7. 怎么明白原子性?(同一个事务下,多个操作要么乐成要么失败,不存在部门乐成或者部门失败的情况)8. 乐观锁和灰心锁的区别?(灰心锁假定会发生冲突,会见的时候都要先获得锁,保证同一个时刻只有线程获得锁,读读也会阻塞;乐观锁假设不会发生冲突,只有在提交操作的时候检查是否有冲突)9. 这两种锁在Java和MySQL划分是怎么实现的?(Java乐观锁通过CAS实现,灰心锁通过synchronize实现。

mysql乐观锁通过MVCC,也就是版本实现,灰心锁可以通过select... for update加上排它锁)9. HashMap为什么不是线程宁静的?(多线程操作无并发控制,顺便说了在扩容的时候多线程会见时会造成死锁,会形成一个环,不外扩容时多线程操作形成环的问题再JDK1.8已经解决,但多线程下使用HashMap还会有一些其他问题好比数据丢失,所以多线程下不应该使用HashMap,而应该使用ConcurrentHashMap)10. 怎么让HashMap变得线程宁静?(Collections的synchronize方法包装一个线程宁静的Map,或者直接用ConcurrentHashMap)11. 两者的区别是什么?(前者直接在put和get方法加了synchronize同步,后者接纳了分段锁以及CAS支持更高的并发)12 .jdk1.8对ConcurrentHashMap做了哪些优化?(插入的时候如果数组元素使用了红黑树,取消了分段锁设计,synchronize替代了Lock锁)13. 为什么这样优化?(制止冲突严重时链表多长,提高查询效率,时间庞大度从O(N)提高到O(logN))14. redis主从机制相识么?怎么实现的?15. 有过GC调优的履历么?(有点虚,答得不是很好)16. 有什么想问的么?三面1. 简朴自我先容下2. 监控系统怎么做的,分为哪些模块,模块之间怎么交互的?用的什么数据库?(MySQL)使用什么存储引擎3. 为什么使用InnnoDB?(支持事务、聚簇索引、MVCC)4. 订单表有做拆分么,怎么拆的?(垂直拆分和水平拆分)5. 水平拆分后查询历程形貌下6. 如果落到某个分片的数据很大怎么办?(根据某种规则,好比哈希取模、range,将单张表拆分为多张表)7. 哈希取模会有什么问题么?(有的,数据漫衍不均,扩容缩容相对庞大 )8. 分库分表后怎么解决读写压力?(一主多从、多主多从)9. 拆分后主键怎么保证惟一?(UUID、Snowflake算法)10. Snowflake生成的ID是全局递增唯一么?(不是,只是全局唯一,单机递增)11. 怎么实现全局递增的唯一ID?(讲了TDDL的一次取一批ID,然后再当地逐步分配的做法)12. Mysql的索引结构说下(说了B+树,B+树可以对叶子结点顺序查找,因为叶子结点存放了数据结点且有序)13. 主键索引和普通索引的区别(主键索引的叶子结点存放了整行记载,普通索引的叶子结点存放了主键ID,查询的时候需要做一次回表查询)一定要回表查询么?(纷歧定,当查询的字段恰好是索引的字段或者索引的一部门,就可以不用回表,这也是索引笼罩的原理)14. 你们系统现在的瓶颈在那里?15. 你计划怎么优化?简要说下你的优化思路16. 有什么想问我么?四面1. 先容下自己2. 为什么要做逆向?3. 怎么明白微服务?4. 服务治理怎么实现的?(说了限流、压测、监控等模块的实现)5. 这个不是中间件做的事么,为什么你们部门做?(其时没有单独的中间件团队,微服务刚搞不久,需要举行监控和性能优化)6. 说说Spring的生命周期吧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,说了Remember Set)13. 你提到的Remember 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中的HashMap、TreeMap解释下?(TreeMap红黑树,有序,HashMap无序,数组+链表)3. TreeMap查询写入的时间庞大度几多?(O(logN))4. HashMap多线程有什么问题?(线程宁静,死锁)5. 怎么解决?( jdk1.8用了synchronize + CAS,扩容的时候通过CAS检查是否有修改,是则重试)6. 重试会有什么问题么?(CAS(Compare And Swap)是比力和交流,不会导致线程阻塞,可是因为重试是通过自旋实现的,所以仍然会占用CPU时间,另有ABA的问题)怎么解决?(超时,限定自旋的次数,ABA可以通过原理变量AtomicStampedReference解决,原理使用版本号举行比力)凌驾重试次数如果仍然失败怎么办?(synchronize互斥锁)7. CAS和synchronize有什么区别?都用synchronize不行么?(CAS是乐观锁,不需要阻塞,硬件级别实现的原子性;synchronize会阻塞,JVM级别实现的原子性。使用场景差别,线程冲突严重时CAS会造成CPU压力过大,导致吞吐量下降,synchronize的原理是先自旋然后阻塞,线程冲突严重仍然有较高的吞吐量,因为线程都被阻塞了,不会占用CPU )8. 如果要保证线程宁静怎么办?(ConcurrentHashMap)9. ConcurrentHashMap怎么实现线程宁静的?(分段锁)10. get需要加锁么,为什么?(不用,volatile关键字)11. volatile的作用是什么?(保证内存可见性)12. 底层怎么实现的?(说了主内存和事情内存,读写内存屏障,happen-before,并在纸上画了线程交互图)13. 在多核CPU下,可见性怎么保证?(思考了一会,总线嗅探技术)14. 聊项目,系统之间是怎么交互的?15. 系统并发几多,怎么优化?16. 给我一张纸,画了一个九方格,都填了数字,给一个MN矩阵,从1开始逆时针打印这MN个数,要求时间庞大度尽可能低(心田OS:之前貌似遇到过这题,最优解是怎么实现来着)思考中。

17. 可以先说下你的思路(想起来了,说了什么时候要变换偏向的条件,向右、向下、向左、向上,依此循环)18. 有什么想问我的?二面1. 自我先容下2. 手上另有其他offer么?(拿了蚂蚁的offer)3. 部门组织结构是怎样的?(这轮不是技术面么,不外还是老老实实说了)4. 系统有哪些模块,每个模块用了哪些技术,数据怎么流转的?(面试官有点秃顶,一看级别就很高)给了我一张纸,我在上面简朴画了下系统之间的流转情况5. 链路追踪的信息是怎么通报的?(RpcContext的attachment,说了Span的结构:parentSpanId + curSpanId)6. SpanId怎么保证唯一性?(UUID,说了下内部的定制改动)7. RpcContext是在什么维度通报的?(线程)8. Dubbo的远程挪用怎么实现的?(讲了读取设置、拼装url、建立Invoker、服务导出、服务注册以及消费者通过动态署理、filter、获取Invoker列表、负载平衡等历程(哗啦啦讲了10多分钟),我可以喝口水么)9. Spring的单例是怎么实现的?(单例注册表)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异常处置惩罚的和打印accesslog的问题)13. CAS相识么?(说了CAS的实现)还相识其他同步机制么?(说了synchronize以及两者的区别,一个乐观锁,一个灰心锁)14. 那我们做一道题吧,数组A,2*n个元素,n个奇数、n个偶数,设计一个算法,使得数组奇数下标位置放置的都是奇数,偶数下标位置放置的都是偶数15. 先说下你的思路(从0下标开始遍历,如果是奇数下标判断该元素是否奇数,是则跳过,否则从该位置寻找下一个奇数)16. 下一个奇数?怎么找?17. 有思路么?(仍然是先遍历一次数组,并对下标举行判断,如果下标属性和该位置元素不匹配从当前下标的下一个遍历数组元素,然后替换)18. 你这样时间庞大度有点高,如果要求O(N)要怎么做(思考一会,答道“界说两个指针,划分从下标0和1开始遍历,遇见奇数位是是偶数和偶数位是奇数就停下,交流内容”)19. 时间差不多了,先到这吧。

爱游戏体育官网

20. 你有什么想问我的?二面1. 面试官平和许多,你先先容下自己吧2. 你对服务治理怎么明白的?3. 项目中的限流怎么实现的?(Guava ratelimiter,令牌桶算法)4. 详细怎么实现的?(要点是牢固速率且令牌数有限)5. 如果突然许多线程同时请求令牌,有什么问题?(导致许多请求积压,线程阻塞)6. 怎么解决呢?(可以把积压的请求放到消息行列,然后异步处置惩罚)7. 如果不用消息行列怎么解决?(说了RateLimiter预消费的计谋)8. 漫衍式追踪的上下文是怎么存储和通报的?(ThreadLocal + spanId,当前节点的spanId作为下个节点的父spanId)9. Dubbo的RpcContext是怎么通报的?(ThreadLocal)主线程的ThreadLocal怎么通报到线程池?(说了先在主线程通过ThreadLocal的get方法拿到上下文信息,在线程池建立新的ThreadLocal并把之前获取的上下文信息设置到ThreadLocal中。这里要注意的线程池建立的ThreadLocal要在finally中手动remove,否则会有内存泄漏的问题)10. 你说的内存泄漏详细是怎么发生的?(说了ThreadLocal的结构,主要分两种场景:主线程仍然对ThreadLocal有引用和主线程不存在对ThreadLocal的引用。

第一种场景因为主线程仍然在运行,所以还是有对ThreadLocal的引用,那么ThreadLocal变量的引用和value是不会被接纳的。第二种场景虽然主线程不存在对ThreadLocal的引用,且该引用是弱引用,所以会在gc的时候被接纳,可是对用的value不是弱引用,不会被内存接纳,仍然会造成内存泄漏)11. 线程池的线程是不是必须手动remove才可以接纳value?(是的,因为线程池的焦点线程是一直存在的,如果不清理,那么焦点线程的threadLocals变量会一直持有ThreadLocal变量)12. 那你说的内存泄漏是指主线程还是线程池?(主线程 )13. 可是主线程不是都退出了,引用的工具不应该会主动接纳么?(面试官和内存泄漏杠上了),缄默沉静了一会。

14. 那你说下SpringMVC差别用户登录的信息怎么保证线程宁静的?(适才解释的有点懵逼,一下没反映过来,居然回覆成锁了。大脑有点晕了,此时已经一个小时已往了,感受情况不妙。)15. 这个直接用ThreadLocal不就可以么,你见过SpringMVC有锁实现的代码么?(有点晕菜。)16. 我们聊聊mysql吧,说下索引结构(说了B+树)17. 为什么使用B+树?( 说了查询效率高,O(logN),可以充实使用磁盘预读的特性,多叉树,深度小,叶子结点有序且存储数据)18. 什么是索引笼罩?19. Java为什么要设计双亲委派模型?20. 什么时候需要自界说类加载器?21. 我们做一道题吧,手写一个工具池22. 有什么想问我的么?(感受我许多点都没答好,是不是挂了(效果真的是) )小结头条的面试确实很专业,每次面试官会提前给你发一个视频链接,然后准点开始面试,而且考察的点都比力全。

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

总结从年前开始面试到头条面完或许一个多月的时间,真的有点身心俱疲的感受。最后拿到了拼多多、蚂蚁的offer,还是蛮幸运的。头条的面试对我资助很大,再次谢谢面试官对我的老实建议,以及拼多多的HR对我的烦琐的问题详细解答。这里要说的是面试前要做好两件事:简历和自我先容,简历要好好回首下自己做的一些项目,然后挑几个亮点项目。

自我先容基本每轮面试都有,所以最好提前自己训练下,想好要讲哪些工具,划分怎么讲。那些年看过的书:《Effective Java》、《现代操作系统》、《TCP/IP详解:卷一》、《代码整洁之道》、《重构》、《Java法式性能优化》、《Spring实战》、《Zookeeper》、《高性能MySQL》、《亿级网站架构焦点技术》、《可伸缩服务架构》、《Java编程思想》说实话这些书许多只看了一部门,我通常会带着问题看书,否则看着看着就睡着了,简直是催眠良药。作者 | 未来小娃泉源 | 技术视点博客 | rhwayfun。


本文关键词:2019,年,蚂蚁,金服,、,头条,拼多,多面,经,万字,爱游戏官网

本文来源:爱游戏官网-www.ydgxsy.com

Copyright © 2003-2021 www.ydgxsy.com. 爱游戏官网科技 版权所有  ICP备案:ICP备78053869号-9