Android 项目重构中遇到的小问题(初版)

前言:最近对整体的Android项目进行了初步的整理并设计了一个小小的demo,记录下过程中遇到的一些小问题。此处不进行系统讲解。

重构的目的及解决方案:

  • 1.组件化,提高代码的通用性

鉴于Android端本身是支持多端(用户端/门店端/配送端/OA)项目,必须提高代码的利用率,增加、修改代码的成本。

解决方案

抽离基础组件生成单独的sdk,以aar的依赖形式加入项目中。

  • 2.单元测试,增加项目的稳定性

鉴于现在的代码本身的耦合度比较严重,很难做到单独在JVM上运行单元测试,为了提高项目本身的稳定性,以及降低上线时的项目bug率,单元测试提上日程。

解决方案

使用标准的mvp-clean架构

  • 3.模块化,减少各个模块之间的依赖关系

现有代码各个模块之间的界限不明显,相互之间的关联性严重,有些类的代码本身臃肿,一个类掺杂好几个人的代码,无法确定代码负责人的界限。

解决方案

设立模块负责人的概念,调整gradle的打包方式,将业务拆分为几个模块每个模块需要单独人员进行负责,以gradle plugin的方式区分代码界限,并尽量做到每个模块的自完备性,后期扩展gradle plugin 一键切环境,每个模块可单独为一个project,提升代码编译速度

  • 4.符合项目人员分配

鉴于整体项目组人员多,项目少,拆分模块负责人更多的原因是基于现有项目人员结构,确立代码界限。

  • 5.扩展性,AOP的数据统计

因为现有代码是直接使用的一些三方库并未封装使用,替换底层代码的成本过高。再有进行数据统计的代码进行侵入度过高

解决方案

增加中间层代码,此中间层提供承接的作用,上层的代码都是依托中间层代码调用基础组件

遇到的问题以及解决方案

  • 1.拆分模块,代码隔离

因为本身项目是单一业务线,逻辑简单直接拆分项目为几个module本身增加项目的复杂度,也比利于项目的后期演变。

解决方案

这里使用了P工程的实现,修改了gradle的打包方式,并增加了plugin来check 代码

Android 项目重构中遇到的小问题(初版)_第1张图片
p工程

main:为主工程入口;
p_generate:生成的下沉接口
p_kernel:中间层
p_order/p_my:业务层

  • 2.模块之间的通信

模块之间需要进行activity的跳转,类与类之间的参数传递等。这里主要进行了以下的几处调研:

方式 优点 缺点
eventbus /otto 很好的进行模块通信,自由穿梭于线程之间 需要提供各个模块之间的通用eventObject,频繁使用会打包类之间的依赖关系,debug查找问题比较难
广播 LocalBroadcastManager本地广播 、系统广播可夸进程通信,本身的效率也不低 使用bundle传递无法获知发送端的对象类型,匹配字符串,只能相互定义字符串协议
serviceloader 读取META-INF/services文件 ,可在任意模块读取反射此类 直接使用系统的serviceLoader会造成很多的services文件,需要自定义sdk使用
自定义event接口 动态代理接口,模块之间自由调用,类与类之间的关系依然体现在接口上,debug比较好定位 需要单独写sdk(好在之前已经有过积累直接可以拿来用),接口下沉的问题
ARouter Activity之间的粘滞性减少,不使用隐式跳转即可实现路由 开源的工程功能比较多,有些代码会增加项目体积

综合上面的对比,我们这里选用了自定义Event接口跟ARouter进行模块之间的通信
需要解决的问题:

1.接口下沉,我们这里学习了微信的api概念将接口定义为以api为后缀的文件,将接口写到模块上层,使用gradle plugin进行自动生成接口文件到p_generate 的sdk中,这样我们就可以在上层模块自己定义接口,其他模块也可以相互调用


Android 项目重构中遇到的小问题(初版)_第2张图片

2.关于ARouter的问题,后期会单独自定义路由sdk

总结:以上便是重构中遇到的一些小小问题,总结下来主要的难点是在模块之间的通信问题,好在前人栽树后人乘凉,以上的所有具体实施都是依托别家项目进行的。有关于整体的项目架构,等项目具体实施时在更新,谢谢。

你可能感兴趣的:(Android 项目重构中遇到的小问题(初版))