在 Android 开发者技能中,如果想进大厂,一般拥有较好的学历可能有优势一些。
但是如果你靠硬实力也是有机会的,例如死磕性能优化,成为一名Android性能优化的高手,也算是目前招聘过程中比较稀缺的人才,可以成为你的敲门砖。
近几年的面试也越来越深入,例如如下问题:
- 在之前的项目中做过哪些性能优化,取得过哪些收益?
- 对于App启动时间这块,有什么心得?如果从线程、系统层面出发优化启动速度?
- 对于内存优化,你觉得需要做哪些事情?Java/Native 内存泄露如何检测与处理?
- 流畅性这块,你们 App 的关注的指标是?这块有什么经验?你觉得造成页面卡顿最主要的原因是?有什么通用性的优化方案?
性能优化始终穿插在 App 整个研发生命周期中,不管是从 0 到 1 的建立阶段,还是从 1 到 N 打磨阶段,都离不开性能优化。
当然大多数开发者更多的还是在做业务开发,对于性能优化基本停留在"听说过"或者"简单使用工具"的阶段,其中不乏一些工作多 年以上的 Android 工程师。
当然如果想要精进,不仅要知道如何利用工具做性能优化,还要对底层原理充分了解,对 Linux 底层相关知识也要充分了解,例如你从线程角度做启动优化,你需要了解在 Linux 层线程的 nice 值,线程优先级对调度的影响等…
这样才能够对精通对某一个领域的性能优化。
精通意味着:
- 首先在大厂面试环节,性能优化基本是必问项,你可以展示出个人实力;
- 一旦你进入大厂,对性能优化了解越多,你能够做的事情就越多,产出也会越多,而且可以持续不断的去做。
当然,在一些面试中,也会看到一些朋友写“精通性能优化”,但是让其描述,往往就是一些自己编写的业务,一些去除页面多余嵌套、使用线程池、ViewStub 这些非常浅的方案。
其实更多的,我们还是希望能够听到,线上复杂环境,低端机/弱网等因素下,用户触发的一系列的体验问题。
想要搞清楚这些,那么必须对各种底层原理有着深度的了解,对各种 case非常丰富的经验;很多朋友经常遇到措手不及的问题,大多是因为对出现问题的情况和处理思路模糊不清,导致此原因就是因为没有彻底搞懂底层原理。
比如下面这张Android启动流程图,不少人都看过,但少有人沉下心去仔仔细细的研究过。
作为过来人,我发现很多学习者和实践者都在 Android 性能优化上面临着很多的困扰,比如:
- 工作场景中遇到“性能优化”难题,往往只能靠盲猜和感觉,用临时性的补救措施去掩盖,看似解决了问题,但下次同样的问题又会发作,原因则是缺乏方法论、思路的指引以及工具支持;
- 能力修炼中,缺乏互联网项目这一实践环境,对“性能优化”只能通过理论知识进行想象,无法认识其在工作实战中的真实面目和实操过程;
- 职场晋升中,只管功能开发,不了解组件设计原理,缺少深入地思考与总结,无法完成高并发、高性能系统设计这类高阶工作,难以在工作中大展拳脚,而有挑战的工作往往留给有准备的人。
总之,一旦遇到“性能优化”问题,很少人能够由点及面逆向分析,最终找到瓶颈点和优化方法,而性能优化是软件工程的深水区,也是衡量一个程序员能力高低的标准。
如果你想更好的掌握性能优化相关问题,可以通过下方的学习文档进行参考学习,大家可以直接去
https://qr18.cn/FVlo89
访问查阅完整版。