随着业务的发展和技术的变更,Android开发也经历了以下几个发展阶段:

看似高大上的名词,其实遵循着最简单的原则:分而治之(如何划分就是“架构”,简单的事情如何串在一起就是“接口协议”,CS领域太多这样的例子了。)

我的理解是,模块化/组件化/插件化都是一种广义的模块化,只是它们的实现方式不同而已。

模块化系统案例:

  1. 智能android设备:Launcher, Lock Screen, Live Wallpaper,AppStore,BatteryManager
  2. Hadoop生态系统:HDFS,YARN,MapReduce等

单体应用

业务代码 + 数据存储 + 接口请求 + 日志 等各个模块杂糅在一个module中。
这种结构基本上已经不适用任何项目,只能作为个人的测试或者demo。

优点:

  1. 编译构建简单

缺点:

  1. 无法适用与复杂的业务结构

广义的模块化

“Modular hardware lead to modular software”

模块化特点:

  • 模块间耦合小(模块间一般通过接口进行通信/调用)
  • 模块可替换(接口不变底层实现可替换)

模块化代价:

  • 模块间调用复杂
  • 需要拟定接口协议
  • 兼容性问题(不同的module可能依赖不同的版本)

为什么需要模块化:

  • 实现高内聚低耦合的代码
  • 不同module可以并行开发和测试
  • 灵活的集成/部署/升级

模块化的方式:

    1. 分包
    1. Android studio中分module
    1. 应用拆分(一个应用拆分成多个应用)

侠义的模块话

android开发时,狭义的模块话就是在project中建立多个module。比如将数据库的处理建立一个module,业务代码建立一个module(业务很复杂的化也可以根据业务场景进行拆分),日志埋点作为一个module等

组件化

组件化是在狭义模块化思想上的一次演进,一个变种。

组件化的核心是角色的转换。 在打包时, 是library; 在调试时, 是application。

A在开发测试业务1时就可以把“业务1”作为一个Application,进行构建测试。 当需要构建整个App时,“业务1”又是一个library,构建脚本就能控制这一切。

看似很简单,但是业务场景千奇百怪,还有很多问题需要解决:

  1. 业务模块之间的通信: 如果时统一进程直接定义接口即可,跨进程可考虑使用AIDL
  2. Main Activity入口问题: 脚本控制使用不同的AndroidManifest文件
  3. activity跳转问题:

插件化

待补充

实例: 微信客户端架构演进

参考:https://www.infoq.cn/article/wechat-android-app-architecture/

参考

架构——android架构演进概述的更多相关文章

  1. TOGAF架构内容框架之概述及架构工作产品分类

    TOGAF架构内容框架之概述及架构工作产品分类 在TOGAF 9之前的版本中,TOGAF的重点主要集中在企业架构开发方法方面,用于指导其使用者如何在各自的组织中对企业架构进行创建和维护,而对于企业架构 ...

  2. Android架构组件——ViewModel

    概述 ViewModel,从字面上理解的话,它肯定是跟视图(View)以及数据(Model)相关的.正像它字面意思一样,它是负责准备和管理和UI组件(Fragment/Activity)相关的数据类, ...

  3. 字节跳动前技术总监开源分享《Android架构设计权威指南》,YYDS!

    架构就像是一场进化史,根据不同时期的需求,演变出不同的架构,车轮滚滚,到今天,移动端框架百花齐放,让人目不暇接.但是其中的本质是磨灭不了的,换言之根本没有磨灭而是隐藏到了人们所看不到的地方,但是依旧发 ...

  4. 一种更清晰的Android架构(转)

    一种更清晰的Android架构   一种更清晰的Android架构 原文链接 : Architecting Android…The clean way? 译者 : Mr.Simple & So ...

  5. Android 架构

    1.系统架构 Android的系统架构和其操作系统一样,采用了分层的架构.从架构图看,android分为四个层,从高层到低层分别是应用程序层.应用程序框架层.系统运行库层和linux核心层. Andr ...

  6. Android架构分析之Android消息处理机制(二)

    作者:刘昊昱 博客:http://blog.csdn.net/liuhaoyutz Android版本号:4.4.2 在上一篇文章中我们看了一个使用Handler处理Message消息的样例,本文我们 ...

  7. android学习——android架构

    android架构:在了解全局的情况下进行细致化的分析才能更有效的学习android的运行原理,才能更深刻的理解android开发: 1.架构图直观 2.架构详解 2.1.Linux Kernel 2 ...

  8. Android架构分析之使用自定义硬件抽象层(HAL)模块

    作者:刘昊昱 博客:http://blog.csdn.net/liuhaoyutz Android版本:2.3.7_r1 Linux内核版本:android-goldfish-2.6.29 在上一篇博 ...

  9. Android架构设计和软硬整合完整训练

    Android架构设计和软硬整合完整训练 Android架构设计和软硬整合完整训练:HAL&Framework&Native Service&Android Service&a ...

随机推荐

  1. Jconsole/jvisualvm远程监控weblogic中间件配置

    1.进入linu操作界面,进入到启动服务目录下 2.选择要监控的服务的启动项,进入到编辑状态(注意:要先将该文件进行备份),如下图所示 3.修改USER_AGRS域,添加如下内容,注意修改IP USE ...

  2. 【故障公告】再次出现数据库 CPU 居高不下的问题以及找到问题的线索

    非常非常抱歉,今天上午的故障又一次给大家带来麻烦了,再次恳请大家的谅解. 在昨天升级阿里云 RDS SQL Server 实例的配置后(详见昨天的博文),万万没有想到,今天上午更高配置的阿里云 RDS ...

  3. P1073 最优贸易 建立分层图 + spfa

    P1073 最优贸易:https://www.luogu.org/problemnew/show/P1073 题意: 有n个城市,每个城市对A商品有不同的定价,问从1号城市走到n号城市可以最多赚多少差 ...

  4. 牛客多校第五场 F take 期望转化成单独事件概率(模板) 树状数组

    链接:https://www.nowcoder.com/acm/contest/143/F来源:牛客网 Kanade has n boxes , the i-th box has p[i] proba ...

  5. CodeForces 1042 F Leaf Sets 贪心

    Leaf Sets 题意:给你一棵树,树上有n个点,只有一条边的点叫做叶子,现在要求把所有的叶子分组,每个组内的所有叶子的距离都不能大于k. 题解: 我们可以随意找一个不是叶子的节点当做这颗树的根节点 ...

  6. hdu 3709 Balanced Number(数位dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3709 题意:给定区间[a,b],求区间内平衡数的个数.所谓平衡数即有一位做平衡点,左右两边数字的力矩相 ...

  7. 用C#实现的几种常用数据校验方法整理(CRC校验;LRC校验;BCC校验;累加和校验)

    CRC即循环冗余校验码(Cyclic Redundancy Check):是数据通信领域中最常用的一种查错校验码,其特征是信息字段和校验字段的长度可以任意选定.循环冗余检查(CRC)是一种数据传输检错 ...

  8. 解决flutter:unable to find valid certification path to requested target 的问题

    1.问题 周末在家想搞搞flutter,家里电脑是windows的,按照官网教程一步步安装好以后,创建flutter工程,点击运行,一片红色弹出来,WTF? PKIX path building fa ...

  9. git 生成密钥

    1.本地安装好git: 2.桌面右键 Git Bash Here 打开git命令行: 3.ssh-keygen -t rsa -C "nideyouxiang@xxx.com"  ...

  10. Python网络爬虫实战(三)照片定位与B站弹幕

    之前两篇已经说完了如何爬取网页以及如何解析其中的数据,那么今天我们就可以开始第一次实战了. 这篇实战包含两个内容. * 利用爬虫调用Api来解析照片的拍摄位置 * 利用爬虫爬取Bilibili视频中的 ...