您当前的位置:首页 > 电脑百科 > 程序开发 > 移动端 > Android

一文读懂Android架构演进历程

时间:2023-11-08 14:06:29  来源:微信公众号  作者:沐雨花飞蝶

Android架构经历了多次演进,从最初的传统MVC架构到现在的MVVM架构。以下是Android架构的演进历程:

  1. 传统MVC架构(Model-View-Controller):最早期的Android应用程序采用MVC架构,其中Model负责数据的处理和存储,View负责用户界面的展示,Controller负责处理用户输入和业务逻辑。这种架构存在耦合度高、代码复用性差等问题。
  2. MVP架构(Model-View-Presenter):为了解决MVC架构的问题,Android引入了MVP架构。在MVP架构中,Presenter作为中间层,负责处理View和Model之间的交互,将View和Model解耦。这种架构使得代码更加清晰,但仍然存在一些问题,比如Presenter过于臃肿,难以维护。
  3. MVVM架构(Model-View-ViewModel):为了进一步改进架构,Android引入了MVVM架构。在MVVM架构中,ViewModel作为中间层,负责处理View和Model之间的交互,将View和Model解耦。与MVP不同的是,MVVM使用了数据绑定机制,使得View和ViewModel之间的数据同步更加方便。这种架构使得代码更加模块化、可测试性更强,提高了开发效率。
  4. MVI架构(Model-View-Intent):为了进一步改进架构,Android引入了MVI架构。在MVI架构中,Model代表应用程序的状态和数据,View代表用户界面,Intent代表用户的操作和意图。当用户在View上进行操作时,View会将Intent发送给Model,Model根据Intent的内容更新自身的状态,并将新的状态发送给View进行展示。这种单向数据流的设计使得应用程序的状态变化可预测且易于调试。

总结来说,Android架构经历了从传统MVC、MVP、MVVM再到MVI的演进过程。其中MVVM架构在Android开发中得到了广泛应用,它能够提高代码的可维护性和可测试性,使得开发更加高效。

MVC架构

MVC(Model-View-Controller)架构将应用程序分为三个主要部分:模型(Model)、视图(View)和控制器(Controller)。

  • 模型(Model):模型负责处理数据和业务逻辑。它是应用程序的核心部分,负责管理数据的获取、存储、处理和更新。模型通常包含数据实体类、数据库操作、网络请求等。
  • 视图(View):视图负责展示数据给用户,并接收用户的输入。它是用户界面的一部分,负责显示数据和与用户进行交互。视图通常包含布局文件、界面元素和用户事件处理。
  • 控制器(Controller):控制器负责协调模型和视图之间的交互。它接收用户的输入,并根据输入更新模型和视图。控制器通常包含业务逻辑的处理、事件监听和数据更新等。

在Android开发中,模型和视图是相互独立的,通过控制器进行交互。当用户与视图进行交互时,视图将事件传递给控制器,控制器根据事件更新模型,并将更新后的数据传递给视图进行展示。

MVC架构的优点包括代码分离、可维护性和可扩展性。通过将应用程序分为不同的模块,可以更好地组织代码,使得代码更易于理解和维护。此外,MVC架构也支持模块的重用,可以方便地扩展应用程序的功能。

然而,MVC架构也存在一些缺点。其中一个主要问题是控制器的职责过重,可能导致控制器变得庞大和难以维护。另外,视图和模型之间的直接交互也可能导致耦合性增加,使得代码更难以测试和重构。

MVP架构

MVP(Model-View-Presenter)架构将应用程序分为三个主要组件:模型(Model)、视图(View)和呈现器(Presenter)。

  • 模型(Model):模型负责处理数据和业务逻辑。它可以是从数据库、网络或其他数据源获取数据,并对数据进行处理和操作。模型不直接与视图进行交互,而是通过呈现器来更新视图。
  • 视图(View):视图负责展示数据和与用户进行交互。它通常是Activity、Fragment或View的实现类。视图只负责展示数据和响应用户的操作,不包含业务逻辑。
  • 呈现器(Presenter):呈现器充当模型和视图之间的中间人。它从模型中获取数据,并将数据传递给视图进行展示。同时,呈现器也接收视图的用户操作,并将其传递给模型进行处理。呈现器负责协调模型和视图之间的交互。

MVP架构的优点包括:

  • 分离关注点:MVP架构将数据处理、业务逻辑和用户界面分离开来,使得代码更加清晰和可维护。
  • 可测试性:由于MVP架构将业务逻辑和用户界面分离,因此可以更容易地对业务逻辑进行单元测试。
  • 可扩展性:MVP架构使得应用程序的各个组件之间的耦合度降低,从而更容易进行功能扩展和修改。

在Android开发中,MVP架构可以帮助开发者更好地组织代码、提高代码的可读性和可维护性,同时也方便进行单元测试和功能扩展。

MVVM架构

MVVM(Model-View-ViewModel)架构将应用程序分为三个主要组件:模型(Model)、视图(View)和视图模型(ViewModel)。

  • 模型(Model):模型代表应用程序的数据和业务逻辑。它可以是数据库、网络请求、本地文件等数据源。模型负责处理数据的获取、存储和更新。
  • 视图(View):视图是用户界面的可见部分,负责展示数据和接收用户的输入。在Android中,视图通常是由XML布局文件定义的,可以包含各种UI组件,如按钮、文本框、列表等。
  • 视图模型(ViewModel):视图模型是连接模型和视图的桥梁。它负责将模型中的数据转换为视图可以直接使用的格式,并处理用户输入的逻辑。视图模型通常包含与视图相关的业务逻辑,如数据格式化、数据验证等。

MVVM架构的核心思想是数据绑定。通过数据绑定,视图模型可以直接将数据绑定到视图上,当数据发生变化时,视图会自动更新。这种方式可以减少视图和模型之间的耦合,提高代码的可维护性和可测试性。

在Android中,可以使用DataBinding库来实现MVVM架构。DataBinding库提供了一种简洁的方式来实现数据绑定,可以通过注解和表达式来定义视图和模型之间的绑定关系。

使用MVVM架构可以带来以下好处:

  • 分离关注点:将数据处理逻辑和UI逻辑分离,使代码更加清晰和可维护。
  • 提高可测试性:由于视图模型是独立于视图的,可以更容易地编写单元测试来验证业务逻辑。
  • 重用性:视图模型可以在不同的视图中重用,提高代码的复用性。
  • 可扩展性:通过使用观察者模式,可以轻松地添加新的视图和模型。

MVVM架构是一种强大的架构模式,可以帮助开发者更好地组织和管理Android应用程序的代码。它提供了一种优雅的方式来实现数据绑定和分离关注点,使代码更加可维护和可测试。

MVI架构

MVI(Model-View-Intent)架构将应用程序的逻辑和状态管理清晰地分离,并提供可测试性和可维护性。

MVI架构的核心概念包括:

  • 模型(Model):负责存储应用程序的状态和数据。它是不可变的,只能通过发送Intent来更新。
  • 视图(View):负责显示应用程序的界面,并将用户的操作转化为Intent发送给Model。
  • 意图(Intent):代表用户的操作或系统事件,例如点击按钮、滑动屏幕等。Intent被发送到Model,触发状态的更新。
  • 状态更新器(Reducer):根据接收到的Intents和当前的状态,计算出新的状态。Reducer是一个纯函数,不会有副作用。
  • 视图状态(ViewState):代表View的状态,包括显示的数据、加载状态、错误状态等。ViewState由Reducer根据Model的状态计算得出。

MVI架构的工作流程如下:

  • 用户与View进行交互,例如点击按钮。
  • View将用户的操作转化为Intent,并发送给Model。
  • Model接收到Intent后,根据当前的状态和Intent进行状态更新。
  • Model计算出新的状态后,通知View更新界面。
  • View根据新的状态更新界面显示。

MVI架构的优点包括:

  • 清晰的分离逻辑和状态管理,使得代码更易于理解和维护。
  • 可测试性强,因为Model是纯函数,可以方便地进行单元测试。
  • 支持响应式编程,可以使用RxJAVA等库来处理异步操作。

MVI架构通过将应用程序的逻辑和状态管理清晰地分离,提供了一种可测试和可维护的方式来构建Android应用程序。它适用于中大型应用程序,特别是需要处理复杂状态和用户交互的场景。

MVP/MVVM/MVI对比

MVP、MVVM和MVI都是常见的Android架构模式,各自有其优点和适用场景。总体来说,MVI的数据流是单向的,状态变化由模型(Model)驱动,确保了状态的一致性和可预测性;而MVVM中的双向数据绑定可以简化视图(View)和模型(Model)之间的数据交互,但也可能导致状态管理的混乱。另外,MVI通过响应式数据流实现了对状态变化的高效处理,相比之下,MVP中的视图(View)和模型(Model)之间的交互相对复杂。

  1. MVP的优点是明确的分离了视图和业务逻辑,使得代码更易于维护和测试。但是,由于需要手动处理视图和模型之间的通信,代码量可能会增加。
  2. MVVM的优点是通过数据绑定机制,使得视图和模型之间的通信更加简洁和自动化。同时,视图模型的存在也使得视图的逻辑更加清晰。但是,MVVM需要使用一些额外的框架或库来实现数据绑定,增加了学习和使用的复杂性。
  3. MVI的优点是通过明确的意图传递,使得视图和模型之间的通信更加清晰和可控。同时,MVI也可以帮助开发者更好地处理应用的状态管理。但是,相比于MVP和MVVM,MVI的实现可能会更加复杂。

总结来说,MVP、MVVM和MVI都是为了解决Android应用开发中的代码组织和管理问题而提出的架构模式。选择哪种模式取决于项目的需求和开发者的偏好。无论选择哪种模式,都需要根据具体情况进行合理的设计和实现。对于简单的项目,可以选用不使用框架的策略;对于复杂的项目,推荐使用MVI或MVVM架构模式。



Tags:Android   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
Android Emulator黑屏怎么办 Android模拟器黑屏解决方法
Android Emulator黑屏问题困扰了非常多的玩家,Android Emulator作为一款安卓模拟器,可以让你在电脑上运行和浏览安卓应用程序,但是程序本身不是很稳定,很容易会出现黑屏,启动不了...【详细内容】
2024-03-04  Search: Android  点击:(37)  评论:(0)  加入收藏
Android 谷歌三件套:解锁谷歌生态!
大家是不是遇到这个情况?当我们需要下载一些国外的游戏或者软件的时候,需要在手机里面安装Google Play商店,然后通过Google Play商店下载国外软件!为了帮助大家使用上各种好用的...【详细内容】
2024-01-02  Search: Android  点击:(110)  评论:(0)  加入收藏
Android开发中常见的Hook技术有哪些?
Hook技术介绍Hook技术是一种在软件开发中常见的技术,它允许开发者在特定的事件发生时插入自定义的代码逻辑。常见的应用场景包括在函数调用前后执行特定的操作,或者在特定的事...【详细内容】
2023-12-25  Search: Android  点击:(83)  评论:(0)  加入收藏
在Android应用开发中使用NFC功能
NFC介绍NFC是指“近场通讯”(Near Field Communication),它是一种短距离无线通信技术,允许设备在非接触或极短距离内进行通信。NFC通常用于移动支付、门禁系统、智能标签和其他...【详细内容】
2023-12-22  Search: Android  点击:(102)  评论:(0)  加入收藏
关于Android图像Bitmap类,你要知道的一切
Bitmap介绍Bitmap是一种图像文件格式,它由像素阵列组成,每个像素都有自己的颜色信息。在计算机图形学中,Bitmap图像可以被描述为一个二维的矩阵,其中每个元素代表一个像素的颜色...【详细内容】
2023-12-19  Search: Android  点击:(97)  评论:(0)  加入收藏
Android开发中如何进行单元测试?
单元测试介绍单元测试是软件开发中的一种测试方法,用于验证代码中的最小可测试单元(通常是函数或方法)是否按预期工作。单元测试通常由开发人员编写,旨在隔离和测试代码的特定部...【详细内容】
2023-12-11  Search: Android  点击:(166)  评论:(0)  加入收藏
我的手机我做主,如何为Android手机应用换图标?
作为一名Android用户,你是否曾经为自己的手机桌面感到单调而乏味?虽然Android系统的桌面定制性已经非常强大,但有时候我们还是希望能够在细节上做出一些改变,尤其是对于那些每天...【详细内容】
2023-12-10  Search: Android  点击:(61)  评论:(0)  加入收藏
了解Android系统架构中的HAL硬件抽象层
在Android系统中,HAL的存在使得不同厂商的硬件可以统一被上层的应用程序调用,从而提高了系统的兼容性和可移植性。HAL还可以帮助开发者更方便地开发应用程序,因为他们不需要为...【详细内容】
2023-12-06  Search: Android  点击:(200)  评论:(0)  加入收藏
谷歌 CEO 皮查伊建议 Android 用户不要侧载应用,称非常危险
iOS和Android的一个显著差异是,Android支持用户从第三方渠道安装应用程序(即“侧载”)。然而,谷歌似乎并不希望用户这样做。最近,在与Epic Store的法律诉讼中,谷歌首席执行官桑达...【详细内容】
2023-11-20  Search: Android  点击:(166)  评论:(0)  加入收藏
Android数据对象序列化原理与应用
序列化与反序列化「序列化」是将对象转换为可以存储或传输的格式的过程。在计算机科学中,对象通常是指内存中的数据结构,如数组、列表、字典等。通过序列化,可以将这些对象转换...【详细内容】
2023-11-14  Search: Android  点击:(272)  评论:(0)  加入收藏
▌简易百科推荐
Android Emulator黑屏怎么办 Android模拟器黑屏解决方法
Android Emulator黑屏问题困扰了非常多的玩家,Android Emulator作为一款安卓模拟器,可以让你在电脑上运行和浏览安卓应用程序,但是程序本身不是很稳定,很容易会出现黑屏,启动不了...【详细内容】
2024-03-04  18183游戏网    Tags:Android Emulator   点击:(37)  评论:(0)  加入收藏
Android开发中常见的Hook技术有哪些?
Hook技术介绍Hook技术是一种在软件开发中常见的技术,它允许开发者在特定的事件发生时插入自定义的代码逻辑。常见的应用场景包括在函数调用前后执行特定的操作,或者在特定的事...【详细内容】
2023-12-25  沐雨花飞蝶  微信公众号  Tags:Android   点击:(83)  评论:(0)  加入收藏
在Android应用开发中使用NFC功能
NFC介绍NFC是指“近场通讯”(Near Field Communication),它是一种短距离无线通信技术,允许设备在非接触或极短距离内进行通信。NFC通常用于移动支付、门禁系统、智能标签和其他...【详细内容】
2023-12-22  沐雨花飞蝶  微信公众号  Tags:Android   点击:(102)  评论:(0)  加入收藏
关于Android图像Bitmap类,你要知道的一切
Bitmap介绍Bitmap是一种图像文件格式,它由像素阵列组成,每个像素都有自己的颜色信息。在计算机图形学中,Bitmap图像可以被描述为一个二维的矩阵,其中每个元素代表一个像素的颜色...【详细内容】
2023-12-19  沐雨花飞蝶  微信公众号  Tags:Android   点击:(97)  评论:(0)  加入收藏
Android开发中如何进行单元测试?
单元测试介绍单元测试是软件开发中的一种测试方法,用于验证代码中的最小可测试单元(通常是函数或方法)是否按预期工作。单元测试通常由开发人员编写,旨在隔离和测试代码的特定部...【详细内容】
2023-12-11  沐雨花飞蝶  微信公众号  Tags:Android   点击:(166)  评论:(0)  加入收藏
一篇聊聊Jetpack Room实现数据存储持久性
Room介绍Room 是 Android Jetpack 组件库中的一部分,它是用于在 Android 应用中进行本地数据库访问和管理的库。Room 提供了一个抽象层,使开发者能够更轻松地访问 SQLite 数据...【详细内容】
2023-12-08  沐雨花飞蝶  微信公众号  Tags:Jetpack   点击:(142)  评论:(0)  加入收藏
了解Android系统架构中的HAL硬件抽象层
在Android系统中,HAL的存在使得不同厂商的硬件可以统一被上层的应用程序调用,从而提高了系统的兼容性和可移植性。HAL还可以帮助开发者更方便地开发应用程序,因为他们不需要为...【详细内容】
2023-12-06  沐雨花飞蝶  微信公众号  Tags:Android   点击:(200)  评论:(0)  加入收藏
我们一起聊聊 IntentService 与 Service 的区别?
Service介绍Service组件是Android应用开发中的四大组件之一,用于在后台执行长时间运行的操作或处理远程请求。它可以在没有用户界面的情况下执行任务,并且可以与其他应用组件...【详细内容】
2023-12-06  沐雨花飞蝶  微信公众号  Tags:IntentService   点击:(167)  评论:(0)  加入收藏
Android数据对象序列化原理与应用
序列化与反序列化「序列化」是将对象转换为可以存储或传输的格式的过程。在计算机科学中,对象通常是指内存中的数据结构,如数组、列表、字典等。通过序列化,可以将这些对象转换...【详细内容】
2023-11-14  沐雨花飞蝶  微信公众号  Tags:Android   点击:(272)  评论:(0)  加入收藏
你了解Android中的SELinux吗?
SELinux介绍SELinux(Security-Enhanced Linux)是一种安全增强的Linux操作系统,它通过强制访问控制(MAC)机制来提供更高级别的系统安全保护。相比于传统的Linux访问控制机制(DAC),SEL...【详细内容】
2023-11-09  沐雨花飞蝶  微信公众号  Tags:Android   点击:(263)  评论:(0)  加入收藏
站内最新
站内热门
站内头条