编者按
本文做者:郭孝星
我的主页:https://github.com/guoxiaoxingandroid
从 Android 入行开始,由于工做需求和解决疑难bug的缘由陆陆续续的看过一些源码,但都不成系统,从2016年年末开始,在Github上建了一个Android Open Source Project Analysis,专门针对 Android 7.0 源码进行系统的分析,这是一个从实践角度去分析源码的项目,目前项目一期已经完成。git
更好的阅读体验?👇github
第一次阅览本系列文章,请参见导读,更多文章请参见文章目录。编程
代码版本设计模式
分析思路性能优化
Android是一个庞大的系统,Android Framework只是对系统的一个封装,里面还牵扯到JNI、C++、Java虚拟机、Linux系统内核、指令集等。面对如此庞大的系统,咱们得有必定的 章法去阅读源码,不然就会只见树木不见森林,陷入卷帙浩繁的细节与琐碎之中。微信
写做风格网络
和你们同样,笔者也是在前人的书籍和博客的基础上开始学习Android的底层实现的,站在前人的肩膀上会看的更远。可是这些书籍和博客有个问题在于,文章中罗列了大量的代码,这样 很容易把初学者带入到琐碎的细节之中,因此本系列文章在行文中更多的会以图文并茂和提纲总结的方式来分析问题,关键的地方才会去解析源码,力求让你们从宏观上理解Android的底 层实现。另外,基本上一个主题对应一篇文章,因此文章会比较长,可是文章会有详细的标题划分和提纲总结,能够有的放矢,阅读本身须要的内容。架构
好了,让咱们开始咱们的寻宝之旅吧~😆框架
Android系统架构图
Android系统架构图
从上到下依次分为六层:
在正式阅读本系列文章以前,请先阅读导读相关内容,这会帮助你更加快捷的理解文章内容。
Android窗口管理框架
Android组件管理框架
Android包管理框架
Android资源管理框架
Android进程框架
Android内存框架
Android虚拟机框架
Android界面开发
Androidy应用优化
其余
有兴趣参与此项目的小伙伴能够扫码入群,本群主要讨论Android Framework、主流开源框架以及Android工程化相关技术,本群不是一个读者群,但愿你们每一个人都能成为项目的参与者。另外,为了营造一个 良好的技术氛围,群里尽可能不要灌水闲聊,若是二维码过时能够加我微信allenwells邀请入群。
文章的最后再聊一聊工做这几年来的感悟,其实我一贯是比较少的去聊这些事情,由于以为这些东西讲多了,有点夸夸其谈的感受,可是这几年工做下来,有几点东西确实是感触颇深的,这里 简单总结一下。
客户第一 - 人与人之间的关系
这个挺起来好像有点官僚风的味道,但这里要说的不是咱们产品的客户,而是说咱们本身的客户,有没有想过这个问题,咱们本身的客户是谁?通常说来,咱们向哪些人提供服务,哪些人 就是咱们的客户,好比我任职于公司的平台架构部,咱们向业务研发团队、产品团队,运营团队和测试团队输出产品和工具,因此他们都是个人客户,除了你提供服务的那些人外,你的leader 也是你的客户,他会给你布置任务,你去完成他的任务。
那么什么是客户第一呢?
比方说你的leader在给你布置任务的时候,他会根据他心目中你的能力大小来制定对任务完成结果的预期,他以为以你的能力能够把一个10分的事情作到6分。而后他就会以六分为标准来安排任务,当你最终 完成了这些任务后,他并不会进一步的承认你的能力,由于你作的事情都在他的预期以内。所谓客户第一,就是你须要向办法找到leader以及其余团队对这个事情10分的预期是什么,而后按照这个标准去完成 任务,也就是说要高于客户的预期去完成需求,不仅仅是知足需求,而是去帮助咱们的客户解决更多的问题。
团队合做 - 人与团队之间的关系
团队合做也是个老生常谈的问题,可是吧这一点作好并不简单,尤为是公司愈来愈大,团队愈来愈多的时候,沟通成本就变得十分巨大。团队合做主要解决三个方面的问题:我如何和我所在 的团队进行合做?我所在的团队如何和其余团队合做?我所带领的团队如何和其余团队合做?那全部的退队集合在一块儿,往一个方向去作事
拥抱变化 - 人与产品之间的关系
拥抱变化对产品而言的,咱们所写的程序最终会变成一个产品,去解决某个商业场景下的问题,因此对于咱们来讲,公司的需求也毫不是只是让咱们把程序写好,只是把程序写好是不够的,咱们还须要设身 处地的去考虑客户在使用咱们的产品的时候会遇到哪些问题,若是去优化解决这些问题。也就是说需求是多变的,咱们要设计出能应对复杂需求的产品,拥抱变化的需求。
以上就是想分享的三点,部份内容也都是老生常谈的问题,但不少事情就是这样,万变不离其宗,作人作事的正确方法始终都是不变的。