移动开发中的软件架构

作者: 星禾笔记 | 来源:发表于2017-03-12 10:59 被阅读652次

在移动开发领域,我们往往会遇到软件的可扩展性、可复用性以及可维护性等问题,这就涉及到如何做好软件的架构设计或者重构优化工作。结合实践与思考,本文对其中的Android应用软件架构做些梳理,首先是层次结构划分,其次是技术选型的考虑。

这里层次结构的划分,可以从横向和纵向两个维度来考虑。

横向上的结构层次,主要指代码文件目录结构或者与之对应的“包”(Package)的划分。

对于使用了MVP架构的应用软件,结合实现方案,可以分为ui、presenter、model、server、utils等。其中ui包括各种Activity、Fragment,以及自定义的视图组件、布局组件等。而model包括业务模型、相关数据的定义等,server负责处理软件和服务器的通信接口实现、JSON数据解析等工作。

在ui中,还可以按照业务功能来对Activity、Fragment加以进一步的划分,这样更方便团队分工维护。因为业务功能相关的UI大都体现在Activity或者与之关联的Fragment,这样划分比较简明直观。

纵向上的层次结构,更侧重逻辑调用和依赖关系,可分为业务层和组件层。

其中业务层,用于实现该软件对应的UI界面以及相关的功能逻辑,和用户操作、展示关联较多,可以选择性地使用MVP架构来实现。

因为该架构会增加类的数量并且至少涉及到三个层次的逻辑调用(在业务层之内),建议只用在业务逻辑较多、UI显示相对复杂,或者后续更有可能需要扩展的地方。

具体到相关实现,又有不同的策略,例如我们可以使用Activity/Fragment/Adapter等组件来封装扩展Presenter,规避其复杂的生命周期变化、资源/变量的初始化和释放等操作对业务逻辑的影响。也可以将Activity/Fragment作为视图层主体,通过接口和Presenter实现互相调用。这里还是需要结合业务特点,在架构实现复杂度与可读性、可维护性之间加以权衡,选择合适的实现方案,满足要求即可。

组件层,主要是独立于上述业务逻辑之外的,但与之有一定关联的功能组件,例如推送服务、图像识别、社会化分享以及支付组件等,通常作为模块组件的方式支持业务层。如果进一步细分,组件层还可以分为功能组件和基础组件层。例如网络连接管理、日志管理等组件,相对更为通用,和业务逻辑的直接关联也更少一些,可以认为是基础组件。

在架构设计过程中,通常还涉及到各种技术选型,这也是为了避免重复造轮子,更好地利用已有成果、提高开发效率。例如,业务层选用MVP还是MVVM架构?在哪些子模块使用?组件层,图像异步加载使用UIL还是Picasso?网络连接管理采用OkHttp还是Volley?诸如此类。

这部分涉及较多的开源项目、相关组件以及第三方服务商的优缺点分析,例如不同组件的性能、sdk文件体积、组件的配套使用等因素,后面继续探讨。

相关文章

  • 移动开发中的软件架构

    在移动开发领域,我们往往会遇到软件的可扩展性、可复用性以及可维护性等问题,这就涉及到如何做好软件的架构设计或者重构...

  • 天马行空,漫想杂谈(前言)

    系统架构,设计开发,在软件开发的中前期,是一个重要而又最具考验的工作。行业中,类似系统架构、软件设计思想的...

  • 传统软件开发架构向基于云平台转型之路

    本文目标 本文阐述从传统软件开发架构向基于云平台开发架构发展之路,给传统开发想云原生开发提供参考。 架构概述 软件...

  • Android架构--MVC、MVP、MVVM

    前言 MVC、MVP、MVVM是当下Android开发中主要的项目架构,当你开发一个app时,合理的软件架构有利于...

  • IT项目中的应用架构、技术架构、安全架构、部署架构

    IT项目中的应用架构、技术架构、安全架构、部署架构 在日常软件项目开发与实施中,经常会涉及到各种架构图,如应用架构...

  • MVC开发模式&三层架构

    MVC:开发模式 三层架构:软件设计架构

  • 软件开发

    软件开发[编辑]维基百科,自由的百科全书 ****软件开发**** 软件开发步骤 需求分析 | 软件架构 | 软件...

  • 架构到底做什么

    什么是架构? 架构即决策 什么是决策? 就是对重要的事情的设计和拍板 在软件开发中,我们可以对整个软件本身做个重要...

  • 设计模式

    架构模式:软件设计中的高层决策,例如 C/S 结构就属于架构模式,架构模式反映了开发软件系统过程中所作的基本设计决...

  • 移动应用开发推荐必备技能学习路线

    覆盖整个Android知识体系以及移动混合开发必备知识架构,适用于致力全面掌控整个移动端开发的高级架构师,不仅要知...

网友评论

  • _张逸_:“纵向上的层次结构,更侧重逻辑调用和依赖关系,可分为业务层和组件层。”这个层次其实应该是横向上,也就是所谓水平切割,或者分层架构。

本文标题:移动开发中的软件架构

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