热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

移动开发中的软件架构

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

《移动开发中的软件架构》

在移动开发领域,我们往往会遇到软件的可扩展性、可复用性以及可维护性等问题,这就涉及到如何做好软件的架构设计或者重构优化工作。结合实践与思考,本文对其中的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文件体积、组件的配套使用等因素,后面继续探讨。


推荐阅读
  • mysql 分库分表策略_【数据库】分库分表策略
    关系型数据库本身比较容易成为系统瓶颈,单机存储容量、连接数、处理能力都有限。当单表的数据量达到1000W或100G以后,由于查询维度较多, ... [详细]
  • 车载T-BOX智能网联终端的设计与实现
    本文介绍了一款基于瑞萨RH850微控制器、TICC2640R2F蓝牙微控制器和高通MDM9628处理器的T-BOX车载终端的设计。该终端通过集成CAN总线、GPS定位、数据加密、蓝牙通信和LTE无线数据传输技术,实现了车辆信息的高效采集与云端通信,支持远程车辆控制和诊断等功能。 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • 云屏系统基于嵌入式微系统msOS,旨在解决当前嵌入式彩屏GUI编程中硬件要求高、软件开发复杂、界面效果不佳等问题。该系统通过结合MCU和Android技术,利用Html5+JavaScript实现高效、易用的图形用户界面开发,使嵌入式开发人员能够专注于业务逻辑。 ... [详细]
  • Spring Cloud因其强大的功能和灵活性,被誉为开发分布式系统的‘一站式’解决方案。它不仅简化了分布式系统中的常见模式实现,还被广泛应用于企业级生产环境中。本书内容详实,覆盖了从微服务基础到Spring Cloud的高级应用,适合各层次的开发者。 ... [详细]
  • 本文介绍了MySQL数据库的安全权限管理思想及其制度流程,涵盖从项目开发、数据库更新到日常运维等多个方面的详细流程控制,旨在通过严格的流程管理和权限控制,有效预防数据安全隐患。 ... [详细]
  • 收割机|篇幅_国内最牛逼的笔记,不接受反驳!!
    收割机|篇幅_国内最牛逼的笔记,不接受反驳!! ... [详细]
  • ArchSummit深圳2014将于7月18日拉开帷幕,所有讲师已确认,涵盖9个热门话题,共36场精彩报告。InfoQ中文站提供了详细的讲师和报告列表。 ... [详细]
  • 本文介绍了在一卡通项目中设计加密管理方案时,证书服务器的配置步骤及其在用户权限控制中的应用。首先概述了证书服务器的基本设置,包括操作系统的选择和证书服务的安装,随后详细描述了服务器证书及客户端证书的创建过程。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 数据集成策略:ETL与ELT架构对比及工具选择
    随着企业信息化的深入发展,‘数据孤岛’问题日益突出,阻碍了数据的有效利用与整合。本文探讨了如何通过构建数据仓库解决这一问题,重点分析了ETL与ELT两种数据处理架构的特点及适用场景,为企业选择合适的ETL工具提供了指导。 ... [详细]
  • 历经两个月,他成功斩获阿里巴巴Offer
    经过两个月的努力,一位普通的双非本科毕业生最终成功获得了阿里巴巴的录用通知。 ... [详细]
author-avatar
手机用户2502857113
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有