热门标签 | 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文件体积、组件的配套使用等因素,后面继续探讨。


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文将介绍如何使用 Go 语言编写和运行一个简单的“Hello, World!”程序。内容涵盖开发环境配置、代码结构解析及执行步骤。 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了如何使用Spring Boot进行高效开发,涵盖了配置、实例化容器以及核心注解的使用方法。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文介绍如何利用动态规划算法解决经典的0-1背包问题。通过具体实例和代码实现,详细解释了在给定容量的背包中选择若干物品以最大化总价值的过程。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 深入解析:手把手教你构建决策树算法
    本文详细介绍了机器学习中广泛应用的决策树算法,通过天气数据集的实例演示了ID3和CART算法的手动推导过程。文章长度约2000字,建议阅读时间5分钟。 ... [详细]
  • 本文深入探讨了一家企业的制度体系重构与升级过程,通过具体案例展示了如何在战略意图和管理理念指导下,系统性地提升企业管理制度的有效性和可操作性。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
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社区 版权所有