`

转自(阿里技术)如何在阿里技术面试中脱颖而出

 
阅读更多
转自(阿里技术)
如何在阿里技术面试中脱颖而出?(内部资料)

原创: 宗心  阿里技术  4月2日

阿里妹导读:知己知彼、百战不殆,面试也是如此。只有充分了解面试官的思路,才能更好地在面试中充分展现自己。今天,阿里高级技术专家将分享自己作为面试官的心得与体会。如果你是面试者,可以借此为镜,对照发现自己的长处与不足,有针对性学习成长;如果你是面试官,相信也能通过他的讲述,有所启发。

招聘是团队管理者工作中的重要一环。本文会结合自己亲身经历以及接受的招聘培训,综合分析怎么找到我们要的人,也希望可以通过招聘这面镜子照亮自己,怎样成为一个更好的工程师。

招聘的目的

当今社会,技术已经成为影响商业成功的关键因素,工程师成为了这些公司最宝贵的财富,没有优秀的人组成团队来完成商业目标,公司根本不可能有今天的成就。所以招聘,就是选择最优秀的人。

招什么样的人?

招优秀的人显然是一个很模糊的概念,我们来度量的时候,我个人认为三个因素是最关键的:

技能

工作项目经验,以及解决疑难问题的能力,毕竟招来的人首先必须很好的完成工作,这是最基本的要求,注意,是很好的完成,不是仅仅完成。

潜力

这个概念看起来比较模糊,其实还是比较容易评价的,对计算机相关的专业的知识体系是不是完整,基础是不是扎实,平常是不是喜欢钻研,对这个世界充满好奇心,这几年走下来,沉淀的速度如何,都是判断一个人的潜力的方式,注意我们看潜力主要是基于候选人的之前的成长经历实事求是来看,过去的优秀经历才能给未来背书。潜力和技能的重要性一样重要,我们不能只看眼前,团队是需要不断发展和前进的,所以我们招人应该面向未来。

软实力

软实力这里其实包含了性格,执行力,领导力等方方面面,它代表了候选人是否能快速融入团队,拿到结果,带领团队攻城拔寨,激励和影响身边的人变得更加优秀等等,软实力一般HR肯定会考察,虽然技术面不会特别去关注,但是从面试的过程中可以看出候选人的沟通能力,以及性格相关的特点,也值得我们注意。

说了这么多,其实在招人上有一个对比的标杆,就是你招的人是不是比团队中同一等级中50%的同学优秀,如果你觉得没有他们优秀,那不用纠结,这个候选人不要了,团队必须不停加入更好的同学,才能变得更加强大。


面试的方法

这里结合之前的培训以及自己的真实经历,讲解面试的一些方法。

面试不要做的事

问一些知道性的问题比如问知不知道这个API干什么的,怎么调用,这个命令怎么用的,知道性的知识,google一下或者认真看下文档就应该知道。
问一些特别复杂的问题比如问一个特别复杂的算法,问一个很抽象的大问题,短时间内很难给予回答。
问一些假设性的问题假设你参与了这个项目,你觉得哪几个地方需要优化。

之所以说这些问题不应该问,我认为主要是因为这些很难考察到面试者的真实能力,45分钟的时间本来就很短,有些问题有可能比较偏,有些问题又过于庞大没法一下子描述特别清楚,还有一些问题缺乏上下文,让人摸不到头脑,所以尽量避免这么问问题,另外把握一个重要原则,不要在面试中试图证明别人不如自己,毫无意义,人无完人,总有覆盖不到的地方,按照这个规则招聘,会错过很多优秀的人才。

面试应该做的事

问已经发生的事情

比如面试移动开发者,面试官应该认真看下其做过的App,具体的工作是什么,准备一些相关的问题,这里就可以看出来之前工作中的积累是什么,有多深。

问题解决思路

针对项目经验和一些学习的经验上面,应该问拿到问题以后解决思路是什么,在什么场景下为什么这么做,这里根据面试者的方案,分析的方法论,就可以大致了解面试者是否聪明,知识面是不是够广,遇到问题时会不会举一反三。

具体可以举个简单的例子,很多同学说自己做过架构,然后都会讲自己做了一个解耦和分层的框架,其实这类框架iOS很多,外部github上就有各种方案。在阿里内部手淘早先做的bundle拆分时沉淀的容器规则,天猫开源出去的beeHive,闲鱼内部的Xframework,抑或是服务端的spring mvc,其实都实现了IoC,但实现和思路上都有一些差异,到底为什么这么做,其实是有区别的,这里面就可以看出知识广度,总结和思辩能力,在关键路径上的技术判断。

又比如说,我们总在强调性能稳定性怎么做,业界也有很多方案,到底哪个方案更好呢?答案没有绝对的对错,取决于某个时间点和场景下哪个问题是最核心的突破点,而你的选择标准和落地的技术方案是不是合理(考虑成本,收益,以及后续的风险是什么)。一般来讲,我们更倾向于用系统化的思维看待一个问题,也就是说,相比根据人的经验去识别性能瓶颈,我们更希望能通过自动化,智能化,数据化的方式去解决问题。

少问多听

一般刚开始做面试官的同学很喜欢以问为主,但因为大家的知识体系不太一样,成长环境也不同,直接这么问起来很难就找到面试者的优点,所以尽量让应试者自己陈述,然后以学习和交流的心态针对陈述中存疑的地方再进行发问,会更容易让应试者放松,也更容易让应试者更全面的表达自己。另外,问的差不多的时候,结尾的时候可以补充一句:您觉得刚才的面试中还有哪些我没问到的,您想再补充一下的内容?末了,再问下:我的问题问完了,您有什么想要问我的吗?

知道了应该怎么做,那具体的提问方法有没有什么技巧呢?在招聘中有一个重要的STAR原则,可以跟大家分享。

STAR原则

处境(situation)
在什么样的环境下

任务(task)
接到了什么样的任务

行动(action)
然后具体怎么落地的

结果(result)
拿到了什么结果

我们尽量问清楚对方在什么样的环境下接到这个任务,接到以后是做了什么事情,最后的结果是什么样子的。乍一听,感觉,这不是套路嘛,是不是知道这个原则的人,只要按照这四点编故事,就能通过面试了?当然不是,在叙述过程中,我们应该分辨出STAR中的真假,那下面就举一些例子。
假的STAR

描述含糊不清

比如,我用这个方案解决了这个问题,效果很好,得到了大家的一致好评。注意,效果好是哪里好,有什么度量的标准?一致好评的体现是在具体KPI还是比如团队有个什么奖励之类的。

只表达态度和看法

我觉得线上稳定性非常重要,应该重点解决和持续跟进。如果只有这一句话,没有后面具体认为重要的解决方案的话,这部分的经验难以令人信服。

假设式描述

如果我来做这件事情,我会1234怎么怎么样。前面其实面试应该问的问题里面有提到,我们本身就不应该问假设性的问题,那作为面试者,假设没做过的事情,如果只是看思路还好,但是如果说的天花乱坠,这个时候要警惕了,毕竟说和做之前的差异是很大的。对于假设的事情,面试官是没法评估具体效果的,因为它不像过去已有的项目和工作内容,是有明显结果的,如果对过去结果存疑,后续也可以背调了解具体的情况。

针对假的STAR,我们要甄别分辨出来,引导其表达出真正的情况。

鉴别方式

更多的关心What/How/Why

做了什么事情,具体做的方案1234几步,为什么要这么做,比如图片的优化,最早肯定什么都没有,后续加cache,cache策略又可以升级,包括cache本身的算法以及多级cache的实现,图片尺寸上面后来有做了什么裁切之类的,图片格式上面后续又做了优化等等。

每个阶段不太一样,关注的重点也不一样,刨根问题问一问,会了解是不是真的做过这件事情,另外有一些可能项目做得很久说很多东西忘了,这里我分享一个观点,之前看过一句话,招聘的人中有一种人是比较好的,他总能比较清楚的记住过往项目当中的重点,这样的人在经验沉淀的过程中肯定更快一些,当然这样的同学肯定得归结在聪明一类的人了,当然能记住也说明他可能喜欢总结和回顾,平常的学习习惯应该也比较好。

细节!细节!细节!

很多关键节点的细节很重要,比如网络库的优化。如果你是一个iOS开发,一般都会知道iOS的网络协议优化常采用拦截NSURLProtocol的方式进行,然后针对传统的https协议我们会将其替换成为spdy协议或者http2协议,过程中还有一些httpdns等的优化。但如果你今天希望招聘一个有这部分网络优化经验的同学,怎么判断这个同学有实操的经验呢?你可以让他说细节上面的很多事情,比如说URLProtocol拦截request以后,针对不同的case的降级策略是什么,选择依据是什么?当时遇到了什么其他的坑没有?你自己的做法有什么缺陷?

又比如Weex的实现上面,整个渲染的流程到底是怎样的,渲染部分还有什么优化空间吗?或者说这个方案本身做了哪方面的优化?它的配套工程体系上的问题是什么,你遇到以后是怎么解决掉的,这些在了解大概思路后,都可以往深入再问一下细节的部分,认真研读以及修改过代码的同学,肯定是答得出来的。

其他Tips

你在面试别人,别人也在选择你

面试是双向的,面试官是一个团队对外的门面,不要迟到,提问和交流要尊重面试者,让面试者感受到我们的真诚。

为未来招聘而不是现在

我们永远应该为未来招聘,因为招聘的人入职也是发生在未来,不能立刻就解决你眼前的问题,所以我们招聘的时候也放长远一点,招为团队未来更有好处的人。

面试是一面镜子

以人为镜,优秀的面试者给我们能带来新的思路和新的方法,而差强人意的面试者则提高我们看人的能力,为后续的提升招聘效率找到更正确的人打下基础。

技术人如何不断成长?



招聘,培训,人才选拔晋升,我认为评价标准和方法都应该有比较多的重合的部分,我们从刚才的面试经验中,反思下,如果现在是我们去找工作,这个市场或者团队更需要什么样的人?

经验丰富,知识体系完整

经验能解决实际的问题,另外知识体系可以让你在遇到新的问题时举一反三,当然大公司和小公司要求的知识体系又不太一样,大公司更偏向一专多能的T型人才,小公司更喜欢全栈,所以到底要成为什么样的人,跟你的职业规划很有关系,是想在大公司成就一番事业,还是出去闯荡,那你点的技能树肯定是不一样的。到底应该怎么做,我自己的经验是,找到身边的标杆,向更优秀的同学学习,在阿里当然非常优秀的专业人才也好,架构师也好,都非常多,所以标杆应该也好找,业界当然也有很多成功的人,有了标杆,就努力向上吧。

保持良好的习惯,不忘总结和提升

当我还是一个菜鸟的时候,当时的老板问了我一个问题,每周写周报的时候,想想自己这一周到底收获了什么,这给我留下了很深的印象。我在想,既然我每次面试别人都问你最近有研究什么新的技术或者看到什么有趣的文章没有的,那我自己是不是能这样要求自己呢?不积跬步无以至千里,贵在坚持积累。

最后打个广告~欢迎大家加入阿里巴巴闲鱼团队!闲鱼目前是业内第一的闲置交易社区,拥有海量用户和巨大的技术挑战,欢迎有移动端跨平台架构经验及人工智能经验的同学联系我们,简历投递方式:christ.yuj@alibaba-inc.com



你可能还喜欢
点击下方图片即可阅读



阿里技术谁最牛?是时候告诉你真相了



如何快速成长为技术大牛?



阿里新突破!
自主创新的下一代匹配&推荐技术



关注「阿里技术」
把握前沿技术脉搏
阅读 70384208
精选留言
写留言
89
像我这样的人、
面试就是一个互相喜欢的人走到一起!
48
姜某人
我有种我离阿里更近了的错觉
37
MengUer
哇⊙∀⊙!前天面试我的一个面试官具备你刚刚说的所有缺点!我当时觉得很反感,技术是不存在唯一性的 能解决问题的方法就是好方法呀!
17
魏伟
最近也在帮团队招聘工程师,学习了 ...
8
忘忘
上周接过阿里的电话面试,小编写的内容,面试官基本都具有,感觉像是统一培训过。阿里人注重基础知识,基础原理,这和企业处于哪个生命周期的阶段有关系。并不是任何人都适合去阿里,阿里也不是都适合任何人
8
春华秋实
觉得和我招人的经验很像啊
5
大海
同学这一称呼用得好。
4
迟明 Jimmie
闲鱼团队在杭州还是北京?
4 作者
杭州~
4
菜刀文
写的特别棒,举的正例,反例很到位
4
王帅
努力!!!不断学习,终身学习
3
东虫夏草
确认过眼神 我遇上对的人
2
一lv阳光
闲鱼,我来了
2
devin
您觉得刚才的面试中还有哪些我没问到的,您想再补充一下的内容?末了,再问下:我的问题问完了,您有什么想要问我的吗?

巧了,这句我经常问
2
春平
明天要去面试了,感谢!
2
子非我
很有启发,最近就是多平台、多语言瞎搞。
2
2018 花开富贵
谢谢小编,写的太好了,看你文章,如沐春风~加油
2
分享到:
评论

相关推荐

    2021最新面试经验,包括百度、阿里、美团、字节跳动算法面试题总结经验

    在IT行业的求职过程中,面试是决定能否进入心仪公司的关键环节,尤其对于技术岗位,算法面试题往往是考察候选人技术功底的重要标准。这份2021年的面试经验汇总,涵盖了百度、阿里、美团、字节跳动等知名互联网企业的...

    阿里校招面试笔试题

    阿里作为中国顶尖的互联网巨头,其校招面试笔试...为了准备这些面试题,应聘者需要不断巩固基础知识,提高编程实战能力,同时关注行业动态和技术趋势,了解阿里巴巴的业务和文化,这样才能在竞争激烈的校招中脱颖而出。

    阿里巴巴面试大礼包(最近几年阿里巴巴笔试和面试题)

    阿里巴巴作为中国乃至全球知名的互联网科技巨头,其面试过程备受求职者关注。这个“阿里巴巴面试大礼包”涵盖了近年来阿里巴巴在笔试和面试中所使用的题目...通过深入学习和实战练习,才能在阿里巴巴的面试中脱颖而出。

    阿里技术精选--不止代码(codelife)

    此外,文章中还提到了一些有助于技术成长的其他话题,比如如何在阿里技术面试中脱颖而出、如何正确使用开源项目、前端工程师的职业发展、架构师的修炼之道以及值得反复阅读的技术书籍推荐等。 从李运华的总结中我们...

    毕业季分享-阿里面试经验

    总之,成功通过阿里的面试并非易事,但通过充分的准备、扎实的技术基础和良好的心态,毕业生们完全有可能在竞争中脱颖而出。希望这些面试经验能为即将踏入职场的你带来启示,祝你求职顺利,收获满意的工作机会!

    阿里美团滴滴京东终极面试指导.txt打包整理.zip

    这份压缩包文件显然旨在帮助求职者在这些公司的招聘过程中脱颖而出,尤其对于寻求在IT行业,特别是云计算领域发展的职业人士而言,具有极高的参考价值。 1. **面试技巧与策略** - 面试前的准备:了解公司文化、...

    csdn上阿里巴巴笔试题汇总(实习生 校招)

    在IT行业中,实习和校招是许多学生和初级开发者进入知名公司,如阿里巴巴的重要途径。...通过这份“csdn上阿里巴巴笔试题汇总”,考生可以有针对性地进行复习和练习,提高自己的竞争力,争取在应聘过程中脱颖而出。

    BAT科技公司前后端面试宝典

    * 如何真的了解线程池,才能在阿里技术面试中脱颖而出 * 线程池的实现原理和应用场景 六、TCP知识点 * TCP冷门知识点:如何准备阿里技术面试的TCP问题 * TCP协议的实现原理和应用场景 七、阿里技术面试准备 * ...

    腾讯、阿里巴巴、金山面试经验分享

    坚持自己的选择,不断努力提升自己,才能在竞争激烈的IT行业中脱颖而出。 #### 十二、项目实践中融入创新思想 参与项目时,不仅要完成分配的任务,更重要的是能够在项目中提出自己的见解和改进方案。这样既能提升...

    Java面试试题-阿里巴巴

    总的来说,要在阿里巴巴的Java面试中取得成功,你需要扎实的Java基础,对JVM和开发工具的深入理解,熟悉设计模式和实际项目经验,以及对各种框架和技术的掌握。不断学习和实践,才能在这个竞争激烈的领域中立足。

    百度阿里腾讯搜狗网易小米等面试题

    在IT行业中,面试是检验求职者技能和知识的关键环节,特别是对于应届毕业生来说,这是进入知名互联网公司如百度、阿里、腾讯、搜狗、网易和小米等的重要通道。这些公司的面试题通常涵盖广泛且深入的技术领域,旨在...

    阿里面试(java)

    在准备阿里面试的过程中,Java开发者需要掌握一系列关键知识点,这些知识不仅涵盖了语言基础,还包括了高级特性、设计模式、框架应用以及实际开发中的最佳实践。以下是对标题和描述中涉及知识点的详细解释: 1. **...

    阿里巴巴职业发展手册

    #### 四、如何在阿里技术面试中脱颖而出? **关键知识点:** 1. **基础知识扎实:** 对于计算机科学的基本原理和技术基础有深刻理解,这是通过面试的第一步。 2. **实践经验:** 具备丰富的项目经验,能够展示出在...

    阿里Java最新版面试集锦2020.pdf

    【阿里Java最新版面试集锦2020.pdf】涵盖了多个关键的Java技术和概念,这些都是在阿里巴巴这样的大型互联网公司面试中常见的考察点。以下是对这些知识点的详细解释: 1. **红⿊树的特性**: 红⿊树是一种自平衡的...

    如何准备阿里社招面试,顺谈 Java 程序员学习中各阶段的建议1

    【如何准备阿里社招面试,顺谈 Java 程序员学习中各阶段的建议】 在准备阿里巴巴的社会招聘面试时,Java程序员需要关注的...在学习过程中,不断拓宽知识面,提升自己的技术栈,才能在竞争激烈的社招面试中脱颖而出。

    阿里巴巴面试题精讲

    在IT行业中,Java是一种广泛应用的编程语言,尤其在企业级应用和互联网开发中占据着重要地位。阿里巴巴作为全球领先的科技公司,对Java技术的要求自然非常高。...不断学习和实践,才能在竞争激烈的IT行业中脱颖而出。

Global site tag (gtag.js) - Google Analytics