就目前的就业情况来看,学习Android Framework的市场发展空间还是非常可观,毕竟国内的很多手机大厂,比如华为、oppo、vivo、小米等厂商都需要AF开发,更有其他APP大厂在招聘,所以学习Android Framework的前景还是有的。
Android系统架构分为五层,从上到下依次是应用层(System Apps)、应用框架层(Java API Framework)、系统运行库层(Native)、硬件抽象层(HAL)和Linux内核层。其中System Apps和Java API Framework这两层都是使用Java语言开发。先上一张Android系统结构图:
p
p
p
Framework层为开发人员提供了可以开发应用程序所需要的API,系统的应用及我们平常开发应用程序都离不开Framework。
Framework始终穿插在 App 整个研发生命周期中,不管是从 0 到 1 的建立阶段,还是从 1 到 N 打磨阶段,也都离不开Framework。在开发中我们会遇到各种各样的非常奇怪的问题,有些问题是百思不得其解。
这些问题大都是因为我们不了解安卓内部运行原理,而掌握了Framework,这些问题都可以迎刃而解。所以,成为一名Android Framework高手,也是目前招聘过程中非常稀缺的人才,可以成为你的敲门砖。
在大厂面试环节,Framework是必问项:
举个例子,比如你了解 Handler的源码结构,你就可以更好的理解这些概念:
p
为什么不能在子线程更新 UI?
主线程为什么循环却不会卡死?
Thread 和 Handler 的关系
ThreadLocal 做什么的?
ContentProvider、Broadcast、Service是怎么利用 Message 监控 ANR 的?
p
p
p
一旦你进入大厂,对Framework了解越多,你能够做的事情就越多,产出也会越多,而且可以持续不断的去做。
作为过来人,发现很多学习者和实践者都在 Android Framework上面临着很多的困扰。
工作场景中遇到难题,往往只能靠盲猜和感觉,用临时性的补救措施去掩盖,看似解决了问题,但下次同样的问题又会发作,原因则是缺乏方法论、思路的指引以及工具支持;
l 能力修炼中,缺乏互联网项目这一实践环境,对Framework只能通过理论知识进行想象,无法认识其在工作实战中的真实面目和实操过程。
l 职场晋升中,只管功能开发,不了解底层原理,缺少深入地思考与总结,无法完成复杂系统设计这类高阶工作,难以在工作中大展拳脚,而有挑战的工作往往留给有准备的人。
总之,一旦遇到问题,很少人能够由点及面逆向分析,最终找到瓶颈点和最优解决方案,而Framework是Android开发的深水区,也是衡量一个Android程序员能力高低的标准。
近年越来越多的Android工程师开始关注Framework领域,伺机从应用开发深入到系统开发。但是,稍一了解就会发现,Android源码非常庞大,为使整个源码更易更新和维护,它纵向分层,横向模块化,设计非常精妙。
其维护的模块主要包括ActivityManagerService、WindowManagerService、PackageManagerService、PowerManagerService、SurfaceFlinger、通信模块、多媒体模块等,多到眼花缭乱。而且一接触源码,发现得熟悉JNI、读得懂C++、理解Java虚拟机、Linux系统甚至汇编、指令集等等,可谓是困难重重。
Android Framework到底怎么学?成为了很多人当前迫在眉睫的问题。
p
p
入门篇:
把握整理流程最为重要。
比如Android系统启动流程,你先要知道启动电源-->加载引导程序BootLoader-->Linux内核启动-->init进程启动-->Zygote进程启动-->SystemServer进程启动-->Launcher启动。
然后再去了解其中的每一步的流程,比如Zygote启动流程就是,创建Java虚拟机并为Java虚拟机注册JNI方法,创建服务器端Socket,启动SystemServer进程。这个过程,可以不用太在意源码。
p
深入篇:
看源码,原则仍是先把握整体,再了解局部。这个场景下,所有的细节都是不重要的。
比如Activity的启动流程,你不用关心在AMS里面这里跳到那里是干什么,还有ActivityStack以及它的那个SuperXX跳来跳去是在干嘛,你只需了解:在Context里面,通过AMS的Client ActivityManagerNative发起Binder调用进入system_server进程,在AMS里面绕了一圈(处理Activity栈以及生命周期相关),然后通过IApplicationThread这个Binder调用回到App进程的Binder线程池,在线程池里面通过Handler发送Message到App主线程,最终通过ClassLoader加载Activity类,创建对象,回调对应的生命周期,整个过程结束。
千万别一行代码不漏地去查看,只见树木,不见森林,效果不见得好。
刚学习的时候肯定不知道哪些是影响不大的逻辑,所以你需要跟着书籍,博客,让前人带路;如果跟着他们的脚步走通了这条路,那你就自己独立走一遍,这时候你肯定会走丢,然后你跟踪、尝试,接着到达终点。
慢慢地,你自然就知道,哪些重要,哪些不重要。刚看系统源码,肯定一头雾水;万事开头难,在你觉得艰深晦涩的时候,硬着头皮也要看,不要放弃。第一次看可能只是对某些词混了个眼熟,但后面再读就会越来越轻松。
p
高级篇:
边看源码边思考,形成自己的理解。
学而不思则罔,思而不学则怠。带着问题去阅读源码,这里是什么意思?为什么需要这么做?这样的实现是优雅还是俗套?有没有更好的实现办法?如果我来写,我会怎么写?诸如此类,有了思考就有了自己的理解。
p
做笔记也是个不错的办法。
做笔记的重要性在于,它可以记下你自己在某个阶段自己的理解,当你更进一步的时候回头再看当初的理解,想想哪里是对的,哪里又有问题,这是一个相当有意思的过程。
我想每一个人在看自己之前写的代码,都会有在某个地方觉得自己是沙比的时候。根据你学习过程简单总结一下,这样你的元认知能力就得到了提升。
看了上面的介绍,是不是可以开始学习了呢?加油吧!