阿里中间件 6 轮面试被砍的血泪总结

2018-03-20 22:37:03 +08:00
 zacard

背景

年前在 V2EX 遇到阿里中间件的哥们,内推面试。从 2018.02.01 开始到今天 2018.03.20 ,一场浩浩荡荡,跨年,持续了 1 个半月时间的残酷面试终于尘埃落定。遗憾的未能加入阿里中间件部门这个大家庭,让我深感痛惜。

最终未能如愿的原因是“名额有限,有更适合的同学”。这也可能是内推大哥为了顾及我的感受的说辞,可能是最后一面面的不好。

这里凭借隐约的记忆,总结下面试经过。让我自己引以为戒,奋发自强,继续前行

一面

主要问一些 java 基础。包括集合、多线程、ClassLoader、锁、juc 类库等都要知道大致的原理、使用规范、约定

二面

根据项目,深入探讨。你需要清楚你所做项目的关键细节、优化、特点、原理。所用第三方库&中间件等的原理,即使不知道,也要有自己的想法能够说出如何代替实现!而且需要一定的技术知识的广度,对于如何选型,为何这么选型能够说出自己的理由

三面

个人感觉着重技术深度

从 ConcurrentHashMap 一路问到锁&锁优化->LongAdder->伪共享->缓存行填充->cas 等诸多技术细节;

从 hystrix 一路问到原理->自己如何实现->如何优化->响应流编程(reactive streams);

从简单的生产者消费者模式设计到如何高效健壮实现;

等等。

四面

纯 coding。

如何倒序输出单向链表?

个人直接想法是用栈先进后出的特点,把链表数据读到栈里然后输出。

有更好的实现方式吗?

仔细一想,确实不够优雅,还好之前刷过一阵子的 leetcode,一般能用栈解决的都能用递归搞定。换了一种递归实现:

具体看本人的github 传送门

五面

hr 面,唯一一次现场面,一直以为是最后一面呢。

给大家抛出几大深坑问题:

这几个问题,大家深思啊,不多说。

六面

大概晚上 20:00 的时候接的电面。那会刚刚游泳游了大概 2,300 百米,然后又没有吃饭,肚子咕咕叫。忍着接听。

主要问项目情况,然后根据一个项目,问如果量级扩大 1000 倍,你会怎么做?有哪些优化措施?高性能&高可用措施?

后面有点饿的眩晕,不知道怎么结束的。。。

总结

感觉阿里更偏重扎实的基础和解决问题的创意与能力。个人感觉自己缺乏大并发、大流量下面对各种复杂问题的处理经验与解决方案,继续沉淀学习吧。

另外,烦请各位大神指点在下写的博客

29456 次点击
所在节点    职场话题
115 条回复
bravecarrot
2018-03-21 01:41:03 +08:00
楼主很强
v2orz
2018-03-21 04:01:53 +08:00
这是面的 P 几啊
songdezu
2018-03-21 04:40:24 +08:00
哪个部门啊 这么刁难人
hlwjia
2018-03-21 04:53:26 +08:00
可以了,拿着这个可以去刷其他公司面试了 哈哈哈哈哈
TimCheng
2018-03-21 07:23:58 +08:00
希望你把这篇文章发到掘金专栏啊,我门在做春招面试的有奖征文活动。了解一下? https://juejin.im/entry/5aaf2e9f51882555677e5a07
bengol
2018-03-21 07:51:24 +08:00
1000 倍与无限扩展有什么区别?
xhinliang
2018-03-21 08:02:19 +08:00
楼主可以试一下快手~xhinliang#gmail
xiaoyukid
2018-03-21 08:25:18 +08:00
楼主可以的半年后再战
shallyy
2018-03-21 09:02:15 +08:00
厉害了
cyril4free
2018-03-21 09:08:08 +08:00
作为技术被楼主甩好几条街的人.....看来不用想阿里了..
pandachow
2018-03-21 09:21:28 +08:00
毕竟中间件团队……
leeg810312
2018-03-21 09:25:42 +08:00
基础、广度、深度,还有想象中的案例,这是面试技术总监吗?年薪百万?
woodface2233
2018-03-21 09:29:11 +08:00
这个是问的 p8 以上? hr 的问题那种很明显就是坑啊,怎么回答都是给自己下套
woodface2233
2018-03-21 09:30:31 +08:00
如果只是去做个 p6 就不要去了
whypool
2018-03-21 09:39:02 +08:00
到 6 面很厉害了
romanroad6
2018-03-21 09:46:51 +08:00
萌新请教各位大佬,达到楼主这样的水平有什么学习路线吗?
zacard
2018-03-21 09:48:08 +08:00
@lyragosa 哥们过奖了
zacard
2018-03-21 09:49:32 +08:00
@lance6716276 没有更糟,理论上空间复杂度是一样的,但是递归更简洁易懂
iceheart
2018-03-21 09:49:34 +08:00
反转链表的时间复杂度是 O(2n),空间复杂度是 O(1).用栈,时间复杂度仍然是 O(2n),空间复杂度是 O(n)
zacard
2018-03-21 09:50:08 +08:00
@0915240 我研究下如何加,感谢建议

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/439890

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX