android 业务解耦

作者: kkgo | 来源:发表于2017-08-11 14:10 被阅读0次

android 业务解耦


当一个超级android应用由几个甚至几十个大模块组成,需要几十个人同时开发时,业务模块间的低耦合,模块内部高内聚显得尤为重要。提高代码可读性,提高团队之间的协同开发是大家绕不开的话题。在经历了几个比较大型的项目之后,对业务模块解耦的个人心得做个总结。业务解耦主要从下几个层面进行:

一、方法解耦

类中包含的成员方法是业务逻辑的最基本的单元,方法解耦是最低层面的解耦。遵循的基本原则:“一个方法只干一件事情“。不要在一个方法内部再去调另外一个方法,当内部方法使用较多时需要在方法内部做太多的逻辑判断。

二、层次解耦

大家经常采用,mvp,mvc,mvvm架构。mvc其实很难做到层次分明,在业务不复杂的情况下,可以使用。当业务过于复杂时,建议采用MVP(虽然有那么些诟病),层次之间的调用可采用回调方式,不建议采用反射或者类似EventBus的做法,主要是多次的反射调用导致性能问题,另外一个是层次之间调用关系松散,降低代码可读性。

三、功能模块内解耦

1、当一个页面较为复杂时,可以将页面按功能模块拆成多个功能组件,考虑性能问题,功能组件可以采用ViewStub,在使用的时候进行渲染,当然也可以采用Fragment(注意规避多个坑),每个功能组件又可以按层次解耦,比如实现MVP模式。

2、当多个功能业务有重合部分,可抽离公共部分做基础类,各个业务继承基础类

四、功能模块间解耦

1、当业务较为复杂时,大家通常的思路是组件化模块化。可以采用事物总线模型,将各个业务模块抽离接口给其他模块调用。或者采用第五种方式进行解耦。

五、插件之间的解耦

1、可以采用注解的方式将需要暴露给第三方调用的方法,被注解的方法将以注册的方式获取到 方法的定义放到map里,其他插件将以反射的方式进行调用。这里的反射调用并不频繁,对性能影响不大。需要在合适的时候进行注册,以及移除,比如可以在activity的onCreate里注册,在onDestory里进行反注册,这样减少map里方法的数量,避免类被释放造成的调用失败以及list的内存增长。

相关文章

  • android 业务解耦

    android 业务解耦 当一个超级android应用由几个甚至几十个大模块组成,需要几十个人同时开发时,业务模块...

  • 青团社拆包依赖-QDepend

    青团社业务发展愈发多样,Android使用模块化设计进行业务的解耦,在代码都解耦上我们已经有一套方案,但在工程的模...

  • 业务解耦组件

  • 架构设计原则

    架构坚持组件化,持续重构,小而美。架构设计十大原则: 1.全面解耦原则:对业务进行抽象建模,业务数据与业务逻辑解耦...

  • 快速实现顶端导航栏(ToolBar+TabLayout+View

    1、前言 在Android开发前期时,实现一个业务分明的导航栏对后面各业务开发与解耦都有重要意义。现在各种厂商的导...

  • Android-Jetpack-LifeCycle组件的使用

    在软件开发当中,解耦可能是永恒的话题。Android开发当中的解耦体现在系统组件的生命周期和普通组件之间的解耦,L...

  • RocketMQ-入门

    一、MQ应用场景 业务解耦解耦是消息队列要解决的最本质问题。所谓解耦,简单点讲就是一个事务,只关心核心的流程。而需...

  • 使用SpringEvent业务解耦

    说明 用于系统业务之间解耦。需要使用的知识点:1.ApplicationContext,2.Application...

  • 观察者模式结合Android源码

    1.观察者模式最重要的作用? 解耦,将观察者和被观察者解耦。eg:ui层与具体的业务逻辑解耦 2.观察者模式的定义...

  • 在业务代码中植入异步通知功能

    对异步通知的定位,是作为核心业务的一种补充,应该尽量与核心业务解耦。 采用的解耦方式为“事件+监听器”。一些主流的...

网友评论

    本文标题:android 业务解耦

    本文链接:https://www.haomeiwen.com/subject/wnwpnttx.html