news 2026/6/23 21:13:20

【大前端】【Android】一文详解Android MVVM 模式详情解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【大前端】【Android】一文详解Android MVVM 模式详情解析

Android MVVM 模式详情解析

一、为什么需要 MVVM?

在早期 Android 开发中,常见架构是:

  • Activity / Fragment = 上帝类

  • UI 控制 + 业务逻辑 + 网络请求 + 数据处理 全部混在一起

典型问题:

  • ❌ Activity 过于臃肿(上千行)

  • ❌ 逻辑与 UI 强耦合,难以测试

  • ❌ 页面复用性差

  • ❌ 维护成本极高

👉MVVM(Model–View–ViewModel)的核心目标:

分离 UI 与业务逻辑,让界面只负责展示,逻辑由 ViewModel 处理


二、MVVM 架构概览

1️⃣ 架构组成

View(Activity / Fragment) ↓ 观察 ViewModel ↓ 调用 Model(Repository / DataSource)
层级职责
View负责 UI 展示、事件分发
ViewModel负责业务逻辑、状态管理
Model数据来源(网络 / 数据库 / 本地)

三、各层职责详解

1️⃣ View(Activity / Fragment)

只做三件事:

  1. 初始化 UI

  2. 监听 ViewModel 数据变化

  3. 把用户操作交给 ViewModel

❌ View不应该做的事情

  • 网络请求

  • 数据解析

  • 业务判断

示例:

class UserActivity : AppCompatActivity() { private val viewModel: UserViewModel by viewModels() override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_user) viewModel.userLiveData.observe(this) { // 只负责刷新 UI textView.text = it.name } button.setOnClickListener { viewModel.loadUser() } } }

2️⃣ ViewModel(核心)

ViewModel 是 MVVM 的灵魂

职责:

  • 处理业务逻辑

  • 保存 UI 状态

  • 提供可观察数据(LiveData / StateFlow)

特点:

  • 不持有 View 的引用

  • 生命周期比 Activity 长(配置变更不销毁)

  • 可单元测试

示例:

class UserViewModel( private val repository: UserRepository ) : ViewModel() { private val _userLiveData = MutableLiveData<User>() val userLiveData: LiveData<User> = _userLiveData fun loadUser() { viewModelScope.launch { val user = repository.getUser() _userLiveData.value = user } } }

3️⃣ Model(数据层)

通常由Repository 模式组成:

Repository ├── RemoteDataSource(网络) └── LocalDataSource(数据库 / 缓存)

Repository 的职责:

  • 屏蔽数据来源

  • 统一数据入口

  • 控制缓存策略

示例:

class UserRepository( private val api: UserApi ) { suspend fun getUser(): User { return api.getUser() } }

四、MVVM 中的数据驱动思想

1️⃣ 核心理念

UI = 数据的映射结果

不再主动“刷新 UI”,而是:

  • 数据变 → UI 自动更新

Android 常用方案:

技术场景
LiveData传统 Android
StateFlowKotlin 协程
DataBindingXML 直接绑定

2️⃣ LiveData vs StateFlow

对比项LiveDataStateFlow
生命周期感知否(需 repeatOnLifecycle)
Kotlin 友好一般非常好
冷/热流
推荐程度⭐⭐⭐⭐⭐⭐⭐

五、MVVM + Jetpack 推荐组合

官方推荐:

MVVM + ViewModel + LiveData / StateFlow + Room + Retrofit + Hilt

示意图:

UI → ViewModel → Repository → DataSource ↑ StateFlow

六、常见错误 & 反模式

❌ 1. ViewModel 持有 Context / View

class BadViewModel(val context: Context) // ❌

✅ 正确方式:

  • 把资源、Toast、跳转交给 View

  • 或使用 Event 通知


❌ 2. ViewModel 过度膨胀

把所有逻辑都塞进 ViewModel

✅ 建议:

  • 复杂逻辑下沉到 UseCase / Domain 层

  • ViewModel 只做“协调者”


❌ 3. LiveData 用来做一次性事件

例如 Toast / 跳转:

LiveData<Boolean> // ❌ 会重复触发

✅ 正确方式:

  • SingleLiveEvent

  • Channel / SharedFlow


七、进阶:MVVM + Clean Architecture

View ↓ ViewModel ↓ UseCase ↓ Repository ↓ DataSource

优势:

  • 更易测试

  • 复杂业务可控

  • 大型项目首选


八、MVVM 的优缺点总结

✅ 优点

  • 清晰分层

  • UI 与逻辑解耦

  • 易测试

  • 生命周期安全

❌ 缺点

  • 初学成本高

  • 小项目略显“重”

  • 设计不当仍会臃肿


九、什么时候该用 MVVM?

项目规模是否推荐
Demo / 小工具
中型 App
大型 / 长期维护项目⭐⭐⭐⭐

十、一句话总结

MVVM 的本质是:用数据驱动 UI,用 ViewModel 隔离复杂性


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 7:15:40

CS配合CrossC2插件,实现MacOS/Linux上线

前言 我们知道CS原生只支持Windows上线&#xff0c;那么对于MacOS、Linux我们可以通过CrossC2插件实现上线下载地址&#xff1a;https://github.com/gloxec/CrossC2/releases我这里主要是演示上线MacOS&#xff0c;上线Linux是相同的&#xff0c;参考文章&#xff1a;https://…

作者头像 李华
网站建设 2026/6/23 0:53:13

4、Puppet 入门:从基础使用到主从架构搭建

Puppet 入门:从基础使用到主从架构搭建 1. Puppet 类型文档与常用资源类型 Puppet 安装后,代码中内置了类型文档,可通过 puppet describe 命令在命令行打印: puppet describe <type> [-s]若不确定某个类型是否存在,可使用以下命令获取所有可用资源类型的完整列…

作者头像 李华
网站建设 2026/6/23 18:30:57

线性代数(五)向量空间与子空间

根据课程内容&#xff0c;先补充一下置换矩阵和对称矩阵的概念。置换矩阵是用来交换矩阵行数或列数的单位矩阵&#xff0c;对于N阶单位矩阵&#xff0c;其具有N!个不同的置换矩阵。用排列组合的知识可以很容易证明&#xff1a;对于N阶单位阵&#xff0c;第一行可以有个位置可供…

作者头像 李华
网站建设 2026/6/23 8:28:26

matlab debug 调试程序

设置断点(一般在循环之前),点击运行然后点step分步运行点击Quit Debugging 退出调试 如果有改动,保存程序之后,才可以重新设置断点

作者头像 李华