本文来自于腾讯内圈Android大佬分享的面经总结
刚加入 IEG 团队做QQ音乐时,那会儿我才毕业大半年,就在思考这个问题,只不过当时更专注于Android开发领域:安卓开发的核心竞争力是什么?我有一个专门的笔记来记录对这个问题的思考,但是由于版本迭代,最初的答案已经难以追溯,大抵就是在强调安卓平台的一些技术要点吧。
不过经过这几年工作的实践、观察和思考,我越发觉得应该把目光往更基础、更通用也更经久不衰的方向转移,具体的 APP 开发的技巧和范式,其实并不多,基本都可以抽象为软件开发的技巧与范式,无论是安卓还是 iOS,无论是客户端还是后端。当然各个平台各个领域都有其独具特色的 API,对这些 API 烂熟于胸也是一种能力,但有多少项目、多少团队需要这样的能力?对于 API,具备检索与理解的能力就差不多了,烂熟于胸性价比太低,于我是没有任何吸引力的。不过对于前后端这种软件形式而言,前端和后端还是有不同的关注点的,前端注重展示交互,后端则注重大规模高可用,但是我是从事Android,没有过多的了解,这里就不做展开。
那从Android软件工程师的角度出发,核心竞争力或者说核心素养是什么呢?这正是回答“互联网大厂需要怎样的工程师?而我们需要成为怎样的工程师?”这一问题的关键。
下面我仅谈谈个人的几点粗鄙之见,不足之处还请见谅,也欢迎指正。
身为 Android 开发工程师 最重要的就是逻辑和方法论(三板斧);
先要对即将开发的App进行适度的了解,再进行合理的规划,最后有条不紊地执行。
解决 bug:
先得搞清楚出 bug 的根本原因,再想一个能解决当前 bug 又不会引入新 bug 的方案,最后就是编码实现。实现新功能也一样,先得搞清楚新功能的具体要求,再想一个实现新功能又不会引入 bug 的方案,最后编码实现。
前面这两项任务都要求我们对代码库有充分的了解,那如何上手一个新的代码库?更进一步,如何上手一个新的项目?
这项任务我们靠的主要是三板斧的第一步:先搞清楚项目的宏观架构,有哪些模块,各个模块如何交互;再结合具体的业务,搞清楚具体的功能是由哪些模块如何实现的,主要是宏观的逻辑流程和数据流程;最后,上手项目也是为了解决 bug 或者实现新功能,这就回到前面的场景了。
如果我们需要设计一套新的系统或者是App呢?如果Android初级开发的话那这个要求就更高了,但还是可以用我们的三板斧予以解决:
①先搞清楚我们想要实现的目标,结合对具体技术细节的理解,设计解决方案和系统/app结构,最后编码实现。
②设计解决方案和系统结构的过程一定要充分思考和讨论,不断提出质疑和挑战,并对设计方案进行适当调整,确保功能完备、结构清晰、可扩展。
不过在这个学习的过程中,怎么学很重要,Android领域几乎所有的底层知识都浩如烟海,如果随意乱学,没有目的性的学是很难学通透的。我个人比较倾向于学知识学会归纳总结,我每学完一本Android资料都会自己抽时间出来做好总结。
这里免费分享一份我根据自己多年工作经验归纳总结出来的Android面试知识核心手册,但是因为简书的推荐机制不能全部展现,需要的朋友可以【打包去我的Github免费获取】
除了逻辑和方法论,我们还需要在Android开发领域有一定能力和经验的积累,此外,工作中大家通常都是团队作战,因此团队协作也是很重要的能力。积累和协作,这两点的重要性难分先后,更多的是看具体的需求。
从团队协作的角度来讲,通常我们都是希望找到一个好相处的人共事,只要人好,协作技巧可以在工作中进行训练。但这里我想提很重要的两点:沟通与度,保持积极的沟通,及时同步信息,及时抛出问题,但又要适度,不能过度干扰他人。重要信息可以立即同步,同时每日每周都有汇总,遇到自己搞不定的问题,我倾向于超过一个小时就抛出来求助。
在回答这个问题前,首先我想先问一个问题:何谓专家?
我觉得就是在某个领域有很深的理解,洞悉这个领域的历史、现状和未来,有宏观认识还不够,技术细节也得了然于胸,如果是不长期相关领域内的工作、不进行广泛的学习和深刻的思考、不紧跟相关领域技术发展的前沿,应该是无法达到这样的境界的。
当然,参加面试的候选人很可能远没有达到这个境界,但经过一定年限的工作积累,候选人到了什么程度,这应该也是面试官希望了解的。
前面说的这些比较虚,接下来我就“面试指南”这一主题结合我的面试经历谈点实的。
面试经历
其实说实话,我与之前部门的面试官相比,我的面试官经验和经历真的是九牛一毛,前期经常找不到重点,不过经过这篇文章的思考和总结,今后我应该会更加得心应手。
不过在今年的两次腾讯招聘经历中,我印象最深的两点就是:
很多人的Android、Java基础真的很差,北邮北航本硕毕业、工作两三年的,HashMap 的原理、View 绘制流程甚至写个单例都出错;
GitHub、博客真的只是敲门砖,能否通过面试还得看内功;
当时有一位候选人主动找我自荐,我看到他的 GitHub 主页和博客后,确实被惊艳到了。但在面试的时候,他却思维迟缓,条理不清晰,让他介绍开源项目和博客涉及的核心开源框架,却连基本流程都讲不清楚,真是非常遗憾。
另外,招聘的结果也和招聘方与应聘者的需求强烈程度有很大关系,IEG团队招人的需求没那么强烈,很牛的人也未必能通过面试,XXX动招人的需求很强烈,不怎么牛的人也可能通过面试。迫切想找工作的候选人基本不会挑公司,物质自由了的候选人凭什么去你们公司,对吧?
被面试经历
去年上半年的时候正式的面试参加了五场,乐视体育、今日头条、Google 北京、阿里云、Facebook 美国。如我前面所说,Google 北京的招聘需求比较弱,所以问的问题就比较难,再加上我也比较菜,所以就挂了。其他的几家公司,招聘需求都很强烈,所以不怎么牛的我也拿到了 offer。
国内公司面试的问题分为算法和Android两大类,不过都已经整理在我文章上方所分享的资料pdf中了。国外公司的面试问题,基本都是算法,Google 尤甚,Facebook 会问一点点安卓相关的问题,但也以算法为主。
对于算法面试,我觉得很多人可能存在一定误解,这里我想指出实际情况(根据我的经历和我了解到的情况)。
首先,算法面试问的题目通常不会很难,大多都对应于 LeetCode 的 medium 难度,理解了题目的意思之后大多数人都会有一些思路。
其次,回答算法问题,套路很重要:先有简单的版本,再进行优化。衡量优劣的标准自然就是复杂度了,所以我们要能分析自己解法的复杂度。优化到什么程度?这需要结合自己的能力和留给写代码的时间,一定要写出一个完整可用的版本。如果还有时间,就可以继续和面试官探讨可能的优化思路了。
总结归纳就是四个字:择优取之
其实文章标题所提出的问题并没有完全正确、标准的答案,我也只能以一个“过来人”的经验写出来我自己的想法,给大家作一下参考。如有不对、不足之处还望大家提出来更改,最后希望大家面试都能拿到自己心仪的offer。
如需要获取文中分享的这份《Android面试核心知识手册》的朋友,可以【打包去我的Github免费获取】