模块化搭建app

前言

在设计一款软件,往大了说需要考虑
1、与现有软件的兼容性
2、安全可靠性
3、以后的扩展性
在安卓上,往小了说考虑的就多了比如
Java、Kotlin语言的特性、架构模式MVC还是MVVM,一些编程细想OOP,AOP,一些模块化的方法和思想等等,其实还有很多。
从非技术上看
团队的协作,人员的调配,进度的安排,项目的大小、维护的周期等等 都是需要考虑的。
其实网上也有很多人写画过架构,基本上都大同小异,话不多说直接上图

lib_sdk层

这里是一些开发工具包,里面包含所有android需要的包



比如appcompat、kotlin等一些Jetpack必备的,我这里用了一些,但也有的没用到,还是看具体的需求在决定。

lib_base层

这里是一些Base的类,比如BaseActivity,BaseFragment,和一些Utils的封装库,
比如一个图片库,再这里可以进行二次封装,假设我们在用一个图片库,这个图片库作者不维护护着不开发了,然后又有些bug,我们就不需要在所有的地方进行修改,在lib_base层修改就可以了,网络请求的库,一些工具库都可以在这一层封装。

lib_base

我这里没封装太多,只有一些最简单的东西。

lib_service层

这一层是提供模块服务的,这一层主要是接口和接口对象,因为这一层需要被所有的业务模块依赖,让模块与模块之间可以相互调用

lib_service

如图,NewsService接口,里面只有一个打开的方法,NewsInstance类,是一个接口对象。具体实现是由业务模块实现。

//定一个接口
interface NewsService {
    fun start(context: Context)
}
//另一个类定义一个接口对象,这个对象由业务模块 进行实例化
object NewsInstance {
    lateinit var service: NewsService
}
lib_widget层

这一层是一些自定义组件层,本质上也是一个模块,只不过这个模块只有自定义组件和一些修改的组件等等,多加了这一块,是为了把所有的自定义组件和第三方的组件放一起,当然开发中,多人是按模块开发,或者是说某个业务需要一个自定义组件可以在这里进行开发、测试。

module_home、module_news

这一层都是业务模块了,各种Activity,NewsActivity、HomeActivity。。。
这一层依赖了lib_base、lib_service、lib_widget,在这一层为业务模块提供基类方法、组件、工具类等。
base:有各种BaseActivity等,NewsActivity继承BaseActivity,符合依赖倒置原则
service:是各种各种接口,module_news模块完成lib_service中的接口,暴露当前模块的业务,其他模块只能通过这些暴露的方法,去调用。符合接口隔离原则
widget:是各种组件给业务模块提供界面上的需求

module_news

NewsServiceImpl 类,继承了lib_service层NewsService的接口,并完相应方法,比如打开NewsActivity的 override fun start(context: Context) 方法。

//这里继承NewsService接口,完成方法
class NewsServiceImpl : NewsService {

    override fun start(context: Context) {
        NewsActivity.start(context)
    }

}

lib_service层接口对象 就是这个类的实例

module_web、module_flutter

这一层还有web和flutter模块
flutter和上面的业务模块也是相同,通过接口打开flutter模块的界面,当然flutter也需要有导航功能,也就是传入一个参数,具体跳转到flutter模块的那一个页面。
web这里也弄了一个独立进程出来,为什么要独立进程,因为大量的Web页面会导致App内存占用过高,影响到App,比如App打开几个界面,然后打开了WebView加载了网页,导致栈底的界面被销毁,再回去时又需要重新创建,如果没有做好处理很有可能会有空指针错误或者其他错误。具体看这里,独立进程的解决方案,就不多赘述了。

APP

这里是个壳模块,基本上都是集合所有模块组成一个App,基本是初始化、注入一些工作

最后

demo地址
我用了阿里的arouter进行路由跳转,工程用了MVVM和AAC模式进行搭建
工程中用了koin为ViewModel进行注入,网络库也是okhttp,retrofit
异步操作,我使用了kotlin里的协程
整个工程的gradle配置 也是用apply的方式,模块的gradle,应用一个公共的gradle配置,也有一个全局的变量isModule,true、false标志表示是模块还是库模块,默认是false,当为true时模块都变成了可以直接运行的app模块,module_widget也变成了app模块,可以进行单独的 自定义View的开发。
每个模块都有两个Androidmanifest.xml文件,对应当前模块是app模块还是库模块。
模块化有助于多人一起开发,互不干扰,提交git也不需要来回pull、push,每块的资源都有相同的前缀,也不会造成资源id的冲突。对于一些lib层,开发稳定,app项目变多,可以把这层内容上传到maven仓库,直接依赖,也可以搭建私人的maven仓库进行上传。
如果库有什么建议或意见可以共同探讨,或者有更好搭建方式,也可以私信我。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,406评论 5 475
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,976评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,302评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,366评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,372评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,457评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,872评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,521评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,717评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,523评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,590评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,299评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,859评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,883评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,127评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,760评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,290评论 2 342