Android组件化开发实践

Android项目中代码量达到一定程度,编译将是一件非常痛苦的事情,短则一两分钟,长则达到五六分钟。Android studio推出instant run由于各种缺陷一般情况下是被关闭的……
组件化开发可以有效降低代码模块的耦合度,使代码架构更加清晰,同时模块化的编译可以有效减少编译时间,当然总的编译时间是不会减少的,只是App模块化之后开发某个模块时,只需要编译特定模块,可以快速编译调试。

百牛信息技术bainiu.ltd整理发布于博客园

原理

组件化和插件化有些同学有些迷惑,简单来说组件化是在编译期分模块,插件化是在运行期。一般插件化用于动态修复bug或者动态更新模块,相对来说黑科技更多一些。

正常一个App中可以有多个module,但是一般只会有一个module是设置为application的,其他均设置为library,组件化开发就是要每个module都可以运行起来,因此在开发期间每个module均设置为application,发布时再进行合并。

实践

本文主要介绍一下项目组件化开发过程碰到的问题和解决办法,这里以
ModularizationApp项目为例。ModularizationApp是一个组件化的app:

Paste_Image.png

Paste_Image.png

Paste_Image.png

Paste_Image.png

Paste_Image.png

  • 架构

    Paste_Image.png

    其中App是主application,ModuleA和ModuleB是两个业务模块,Library是基础模块,包含所有模块需要的依赖库,以及一些工具类:如网络访问、时间工具等。代码结构如图:

Paste_Image.png

  • Module作为application开发

ModuleA和ModuleB是相对独立的业务模块,可以分别进行开发,编译时只编译自身,具体实现时在gradle.properties中设置变量,如:IsBuildMudle=false
在模块的的build.gradle中:

if (IsBuildMudle.toBoolean()) {
    apply plugin: ‘com.android.application‘
} else {
    apply plugin: ‘com.android.library‘
}

在主模块的build.gradle中设置:

    if (!IsBuildMudle.toBoolean()) {
        compile project(‘:ModuleA‘)
        compile project(‘:ModuleB‘)
    } else {
        compile project(‘:Library‘)
    }

这样每个module就可以独立安装使用了,注意在修改IsBuildMudle的值时,一定要sync gradle
当module单独运行和作为module运行时,其activity在manifest中设置也会不同,这里可以根据IsBuildMudle设置不同的manifest:

    sourceSets {
        main {
            if (IsBuildMudle.toBoolean()) {
                manifest.srcFile ‘src/main/debug/AndroidManifest.xml‘
            } else {
                manifest.srcFile ‘src/main/release/AndroidManifest.xml‘
            }
        }
    }

分别在不同的目录下创建manifest文件。一定要注意两个manifest的同步问题,否则出现了莫名其名的bug,还找不到原因……

  • 资源冲突问题

    当分别开发模块时,容易出资源重复命名的问题,可以在build.gradle中设置

    resourcePrefix "module1_"

    通过给模块设置不同的资源前缀,可以避免重复命名。

  • Activity跳转问题

    拆分业务代码时,自然会涉及到跨module的Activity跳转,当单独编译时,自然是不能获取到其他模块的引用的。有几种方式可以实现跨模块的唤起Activity:

隐式启动
通过设置intent-filter实现,这需要在manifest中插入大量代码,同时也降低了安全性(其他app就可以通过这种方式随意启动)。
通过类名跳转
Android业务组件化开发实践提出了一种通过类名跳转的方式,使用脚本生成Rlist类,比较方便快捷,但感觉不方便activity间传递数据。
Scheme跳转
Scheme的方式是建立映射表,集中处理Activity,这种方式可以传递一定的数据。Activity传递大量数据时可以通过EventBus来进行传递(其实即使通过intent显示启动,也不要把大量数据放置在intent中,intent对数据大小有限制)。
在进行本次实践时找到github上的一个url Router,同时支持http和程序内Activity跳转,而且通过注解的方式进行,使用非常方便,于是引入到了项目中。项目地址ActivityRouterActivityRouter的readme中已经有比较详细的wiki,但是还有一些需要注意的:

依赖问题:

ActivityRouter使用了apt方式,因此每个使用的module中均需要设置

apt ‘com.github.mzule.activityrouter:compiler:1.1.5‘

注意是每个module,在Library module中设置

classpath ‘com.neenbedankt.gradle.plugins:android-apt:1.8‘

即可。

多module问题

ActivityRouter通过注解在编译时生成mapping,如果多个module设置依赖,就会生成多个java文件,导致源文件重复,编译出错,ActivityRouter目前提供了解决方法,但是还没有正式发布版本,可以设置:

compile ‘com.github.mzule.activityrouter:activityrouter:1.1.9‘
apt ‘com.github.mzule.activityrouter:compiler:1.1.6‘

使用。使用在application中注解:

@Modules({"app", "moduleA", "moduleB"})
public class ModularizationApplication extends Application {
}

每个module中创建空java类注解:

@Module("moduleA")
public class ModuleA {
}

具体可以clone ModularizationApp查看代码。

编译运行

当在gradle.properties中设置IsBuildMudle=true时,可以独立运行每个module,独立运行调试,当设置IsBuildMudle=false,可以编译运行整个project,注意IsBuildMudle变量设置改变时,要对gradle进行sy

运行过程中有什么问题可以评论或者在github中提issue。

作者:wutongke
链接:http://www.jianshu.com/p/186fa07fc48a
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

时间: 2024-05-22 15:28:44

Android组件化开发实践的相关文章

Android 业务组件化开发实践

组件化并不是新话题,其实很早很早以前我们开始为项目解耦的时候就讨论过的.但那时候我们说的是功能组件化.比如很多公司都常见的,网络请求模块.登录注册模块单独拿出来,交给一个团队开发,而在用的时候只需要接入对应模块的功能就可以了. 百牛信息技术bainiu.ltd整理发布于博客园 今天我们来讨论一下业务组件化,拿出手机,打开淘宝或者大众点评来看看,里面的美食电影酒店外卖就是一个一个的业务.如果我们在一个项目里面去写的时候,总会出现或多或少的代码耦合,最典型的有时为了赶上线时间而先复制粘贴一段类似的代

Android组件化开发的简单应用

组件化开发的主要步骤: 一.新建Modules 1.新建Project,作为应用的主Module. 2.新建Module:"Common",类型选择"Android Library",作为所有其它Module的基础依赖库. 3.新建Module:"Home",类型选择"Android Library",依赖"Common". 4.新建Module:"Project",类型选择"

Android组件化最佳实践 ARetrofit原理

简介 ARetrofit是一款针对Android组件之间通信的框架,实现组件之间解耦的同时还可以通信. 源码链接:https://github.com/yifei8/ARetrofit欢迎star.issues.fork 组件化 Android组件化已经不是一个新鲜的概念了,出来了已经有很长一段时间了,大家可以自行Google,可以看到一堆相关的文章. 简单的来说,所谓的组件就是Android Studio中的Module,每一个Module都遵循高内聚的原则,通过ARetrofit来实现无耦合

vue.js组件化开发实践

前言 公司以往制作一个H5活动,特别是有一定统一结构的活动都要每次用html.css.js滚一次重复的轮子,费时费力.后来接到了一个基于模板的活动发布系统的需求,于是就有了下面的内容. 开始 需求一到,接就是怎么实现,技术选型自然成为了第一个问题.鉴于目前web前端mvvm框架的流行,以及组件化开发方式的出现,决定采用vue进行开发. 这里首先简单说下web前端组件化开发方式的历程: 最早的组件化结构,或者叫做组件化1.0时代,代码结构可能如下: 1 - lib/components/calen

Android组件化开发(注意事项)

1.Manifest合并 在Android studio编译项目时,无论你使用了几个Module都会把所有Manifest最终合并成一个,需要我们注意的是application标签下这个几个属性引用的值. 如果项目里有多个相同名字的资源,在编译时会不知道引用那个资源而导致Manifest合并失败. 解决方法:在主 Module Manifest application 加入红色标记的部分,原理就是以当前Manifest引用的资源为准. <application android:icon="

Android组件化框架设计与实践

在目前移动互联网时代,每个 APP 就是流量入口,与过去 PC Web 浏览器时代不同的是,APP 的体验与迭代速度影响着用户的粘性,这同时也对从事移动开发人员提出更高要求,进而移动端框架也层出不穷. 上图显示的是传统的服务端架构和客户端 App 架构对比.传统的服务端架构中最底下是一个 OS,一般是 Linux,最上面服务端的业务,而中间有非常多的层次可以在架构上,按照我们的意愿搭建中间的各个层次的衔接环节,使得架构具有足够的灵活性和扩展性.但是到了 App 就会面对一个完全不同的现状,App

Android项目模块化/组件化开发(非原创)

文章大纲 一.项目模块化初步介绍二.项目模块化的两种模式与比较三.大型项目模块化的演进四.项目模块化总结五.参考文章 一.项目模块化初步介绍 1. 前言 在Android开发中,随着项目的不断扩展,项目会变得越来越庞大,而随之带来的便是项目维护成本与开发成本的增加!每次调试时,不得不运行整个项目:每当有新成员加入团队时,需要更多的时间去了解庞大的项目...而为了解决这些问题,团队通常会将项目模块化,以此来降低项目的复杂度和耦合度,让团队可以并行开发与测试,让团队成员更加专注于自己所负责的功能模块

Android组件化和插件化开发

http://www.cnblogs.com/android-blogs/p/5703355.html 什么是组件化和插件化? 组件化开发就是将一个app分成多个模块,每个模块都是一个组件(Module),开发的过程中我们可以让这些组件相互依赖或者单独调试部分组件等,但是最终发布的时候是将这些组件合并统一成一个apk,这就是组件化开发.插件化开发和组件化开发略有不用,插件化开发时将整个app拆分成很多模块,这些模块包括一个宿主和多个插件,每个模块都是一个apk(组件化的每个模块是个lib),最终

Android适合组件化开发的路由框架:Launch

1.概述 最近越来越不想写代码了,特别是一些重复性的代码,比如由于每次启动一个 Activity,我们都会很习惯的在 Activity 中写下: public static void launch(Activity activity) { Intent intent = new Intent(); intent.setClass(activity, xxxActivity.class); activity.startActivity(); } 已经有两年Android开发经验的我掐指一算,好像有