mvp的全称_是让人提神醒脑的 MVP、MVVM 关系精讲!

前言

很高兴见到你!

我是《Jetpack MVVM 精讲》的独立原创作者 KunMinX,GitHub star 8.7k,专注于深度思考和 Jetpack MVVM 的分享。

关于 MVP 和 MVVM 本质和区别的文章,本来我是不想写的,因为经过长达一年的耳濡目染 和对方法论的试炼,相信 但凡沉下心阅读过《重学安卓》体系化文章的读者,多已练就 透过表象迅速抓住本质 的稀缺能力。

专栏每天都有新的读者加入,然而没想到的是,1 年了,仍然时不时的会被咨询、或是在各个社区看到人们众说纷纭地在谈论 MVP 和 MVVM 谁“好”谁“坏”。

6feb35d0e62e21d1a6d3bfb9fa6bbf4c.png

并不是每一个提问都值得被回答

爱因斯坦说,“提出正确的问题,问题就已解决了一半”。

换言之,并不是每一个提问都值得被回答。一次提问所包含的信息量,其实远远超出内容本身

透过提问者的提问,几乎可以瞬间感知到,提问者对事实状况的掌握程度,并由此来决定到底值不值得继续交流。

与“高”质量提问者的交流 让人感到如沐春风 —— 几句话就能自己先把背景交代清楚,然后就某个细节提出自己的困惑 —— 这让我不免想要与之多聊几句,把我知道的毫无保留地分享出去。

反之,“低”质量提问 让人感到 不舒服,甚至不对劲 —— 明明不遗余力地在多处 划重点 反复交代,明明白纸黑字写得清清楚楚,甚至段落、链接给他指出来,却视而不见,就好像从未发生过。

注:我从不在技术交流中使用 “高”、“低”、“好”、“坏”、“轻”、“重” 之类的主观描述,此处只是以多数人方便理解的方式来介绍。文中使用到的主观描述一律加上双引号。

更有甚者,为了满足抬杠的快感,不惜浪费彼此的时间 ? ... ?

本质和区别,我只说一遍

事实上,我并不会去判断来者是否是来抬杠,而只须透过对方所说的话,即可瞬间判断对方说的是事实,还是自顾自地扯淡 —— 你没法和一个前来扯淡的人交流,你会发现 这种对话往往 存在巨大的代沟,并且抬杠者无意谋求和缝合对事实的理解,他本来就是为了 “来的快” 的精神胜利而来。

事实即 "就事论事",事实必有特定背景和目的来约束。一切脱离事实特征的意见和观点都是瞎扯淡,没有讨论的前提、不值得参与 —— ©KunMinX

所以,本文只写给那些 真的想搞清楚事实 的有缘人,只为有缘人铺路。

并且关于 MVP 和 MVVM 各自的本质及区别,我就只说这么一遍,所以请认真阅读。

文章目录一览

  • 前言

  • 并不是每一个提问都值得被回答

  • 本质和区别,我只说一遍

  • 先说结论

  • 所以二者的区别是什么?

  • Jetpack MVVM 和 MVVM 模式的关系

  • 我为什么能瞬间感知沟通质量的 “好” 与 “坏” ?

  • 综上

先说结论

MVP 本质:是广义上的架构模式,适用于面向实体或虚拟用户接口的开发。

它主要是在 MVC 的背景下,通过 依赖倒置,来解决 逻辑复用 难、实现更替 难 的问题。

MVVM 本质:是狭义上的架构模式,专用于页面开发

它主要是在多人协作的软件工程的背景下,通过只操作 ViewModel 中映射的视图数据 来刷新视图状态,以此来解决 视图调用的一致性问题 从而规避不可预期的错误。

所以二者的区别是什么?

区别就在于:

一个是广义上的架构

你可以通过同一套逻辑去驱动不同品牌设备的实体用户接口(比如不同品牌的耳机线控),或虚拟用户接口(比如 Android 视图,但存在一致性问题而不推荐);

e38daf7c47159f7b7535d55cca00f023.png

一个是狭义上的架构

专用于可视化页面的开发,通过解决一致性问题 来规避不可预期的错误。

c7a4abb4eeee10321400d189e7b49e4d.png

所以轻易地你就可发现,二者分别适用于 在各自的专场下 解决不同的问题,根本没有可比性,更没有所谓的 谁“好”谁“坏” 之分。

而且除了没有可比性,二者之间其实也没任何关系,MVP 的特质是 依赖倒置,MVVM 的特质是 数据驱动,二者没有说谁演化自谁的关系。回到刚刚所说的:“根本就是 特定场景下解决特定问题 的两种截然不同的架构模式”。

没有所谓的 MVVM == MVP + DataBinding,没有的。

Jetpack MVVM 和 MVVM 模式的关系

Jetpack MVVM 是 MVVM 模式在 Android 开发中的一个具体落实,也即它不仅仅包含了 MVVM 模式用于解决 “视图调用的一致性问题” 这一本质,还兼顾了 Android 页面开发中其他不可预期的错误。

正如我在《 Jetpack MVVM 精讲》中介绍到的:

Lifecycle 的存在,主要是为了解决 生命周期管理 的一致性问题

LiveData 的存在,主要是为了帮助 新手老手 都能不假思索地 遵循 通过唯一可信源分发状态 的标准化开发理念,从而在快速开发过程中 规避一系列 难以追溯、难以排查、不可预期 的问题。

ViewModel 的存在,主要是为了解决 状态管理 和 页面通信 的问题

DataBinding 的存在,主要是为了解决 视图调用 的一致性问题

它们的存在 大都是为了 在软件工程的背景下 解决一致性的问题、将容易出错的操作在后台封装好,方便使用者快速、稳定、不产生预期外错误地编码

8c78d2c32cd2410f40733028926fb618.png

所以,Jetpack MVVM 的高频核心架构组件,和 iOS、WPF 的实现一定是有区别的,只不过抓住本质,我们就能举一反三,以不变应万变。

通过《事关软件工程安全 的 数据驱动 UI 框架 扫盲干货》一文的介绍我们可知,DataBinding 的唯一挑战者是 基于函数式编程的数据驱动 UI 框架,也即发源自前端 Elm 框架的 React、Flutter、Jetpack Compose、SwiftUI 之流。

所以 React、Flutter 这种,算不算 MVVM 呢?其实也算。DataBinding 被换下了,但视图调用一致性问题有函数式编程来解决。

所以 ...

我为什么能瞬间感知沟通质量的 “好” 与 “坏” ?

事实上,在 “先说结论” 一节介绍完本质后,按照惯例,我是会以 “如果这样说还没有理解的话” 来引出下文,开始交代 “Before” 和 “After” 的,

因为每天都有新的读者加入,为方便新读者能够 结合自己的兴趣 随机阅读,专栏几乎每一篇文章 都是以独立专辑的完整度来发行

这也是为什么,我的每一篇文章,都当做自己是第一次和读者见面、不遗余力地贯彻 全网独家的深度思考写作风格,让每一位新读者都有机会和我注入到文章的灵魂发生交流。

然而这一次,我不得不小小地任性一把,因为如果上述这样说了一通,还是不理解的话,答案早就写在以下几篇里:

《是 持续增量更新 的 背景缘由甜点》 的 “饭后甜点不能当主食吃” 一节 (推荐)

《基本功:是随时随地可受用的 深度思考秘诀》 的 “所以如何正确地思考” 一节;

《这是一份 简洁有力的 认知地图》 的 “认知地图” 一节;

还有近期在掘金开源的《独家解析 | Android 深度思考写作技巧》 的 “公式” 一节 ——

这几处都有 就正确的思维方式 提供方法论依据 以及手把手示范

一旦熟悉了这套方法论,那些没完没了的争论,你会不会参与?我想大概率不会,因为你一眼就看出 这些言论中不包含基于事实的思考,不过是 凭主观感觉、个人喜好 的自说自话。

参与到这种扯淡中 是对自己的不尊重,所以你不会参与。

综上

MVP 的本质是对 MVC 的依赖倒置,借此来解决 逻辑复用难 以及 实现替换难 的问题,

因为在 MVP 下,UI 逻辑和业务逻辑全在 Presenter 中写,UI 和 Model 的实现,可以随意替换,

也即如上文介绍的,通过同一套 Presenter 中的逻辑,可以驱动不同品牌不同型号的耳机的线控。(注意 UI 的全称是 “用户接口”,台湾的术语更准确,叫 “用户介面”。UI 不是狭义上的页面,UI 就是 UI)

MVVM 的本质是对 View 数据的映射,借此来在软工背景下解决 视图调用的一致性问题。

MVP 和 MVVM 二者的区别在于,前者是广义的架构模式,普遍适用、抓大放小;后者是狭义上的架构模式,专用于页面开发,可以解决例如 视图调用的一致性问题,来规避不可预期的错误。

也即 MVP 和 MVVM 本质上毫无关系,没有谁演化自谁

Jetpack MVVM 是 MVVM 模式在 Android 下的一个落地,也即除了解决 视图调用的一致性问题,还因地制宜地解决了其他一致性问题,从而规避各种不可预期的错误,让软件开发的工作得以完成得又快又好。

这样说,你理解了吗?

版权声明

本文以 CC 署名-非商业性使用-禁止演绎 4.0 国际协议 发行。

Copyright © 2019-present KunMinX

e5df2411d68a8b3349535859e8e51514.png

文中提到的 关于 “MVP 和 MVVV 各自的本质及区别” 的具体描述、”用户介面与耳机线控“ 的举例、”DataBinding 与函数式编程数据驱动框架的关系“ 的具体描述、”Jetpack MVVM 和 MVVM 关系“ 的描述、”Lifecycle、LiveData、ViewModel、DataBinding 等架构组件的存在意义“ 等多处 对特定现象及其本质的概括,均属于本人独立原创的成果,本人对此享有最终解释权。

任何个人或组织在转载全文,或引用本文中上述提到的 描述、举例或本质概括 时,须注明原作者和出处。未经授权不得用于洗稿、广告包装等商业用途。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/364359.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

链家广州二手房的数据与分析——爬取数据

之前在博客分享了利用 R 和 rvest 包爬虫的基础方法。现在就来实战一下:爬取链家网广州 40,000 套二手房的数据。 之前在 Web Scraping with R 说过的爬虫方法在这篇中就不在赘述了。这里就分享怎么样爬取网站中翻页的数据。 >> Web Scraping across Multiple…

Vue脚手架搭建项目

全局安装vue脚手架 $ npm install -g vue-cli 卸载方法 $ npm uninstall -g vue-cli 查看vue版本(注意:大写的V) $ vue -V 创建项目 $ vue init webpack vue-app ? Project name vue-app ? Project description Vue Project ? Author Pr…

es安全组端口_从零开始在远程服务器(Linux)上搭建es,eshead和ik分词器

一、资源准备远程服务器一个(本教程为CentOS 64位)注:ik分词器版本需与es版本统一jdk1.8.0elasticsearch-head-master.zip二、开放端口注:本例采用的是阿里云服务器1.登录阿里云,选择控制台2.找到左上角的三条白线--》…

sipp模拟freeswitch分机测试(SIP协议调试)

1、freeswitch安装 1) 网上很多安装方法都不靠谱,系统版本,各种依赖库一堆问题,下面是验证的可行的。 yum install -y http://files.freeswitch.org/freeswitch-release-1-6.noarch.rpm epel-releaseyum install -y freeswitch-config-vanill…

hd计算机技术,BD和HD的区别是什么?

BD和HD的区别是什么?我们在网上下载电影的时候,往往发帖子的童鞋会提示我们影片的规格,如所谓BD1280或者HD1024等等,一些朋友搞不清楚这是什么意思,实际上我们只能说BD和HD的区别是什么,关于1280和1024那完全是分辨率…

消息提示框-事件冒泡

1 <!DOCTYPE html>2 <html lang"en">3 4 <head>5 <meta charset"UTF-8">6 <title>事件冒泡-提示框</title>7 </head>8 <style>9 button {10 width: 160px;11 height: 30px;12 backgr…

我是如何解决asp.net程序在dreamWeaver中布局乱码的问题

每次把asp.net程序导入Dw2004中时&#xff0c;总是出现乱码&#xff0c;也不知道是什么原因。今天我就换了一个版本&#xff08;DW8&#xff09;&#xff0c;发现以前的问题全都没了。我想肯定是我的DW出现了问题&#xff0c;因为以前也出现过一次&#xff0c;也是重装后解决掉…

分段函数if语句_C语言函数系列之库函数中基础必会函数(一)

&#xff01;&#xff01;&#xff01;阅前提醒&#xff1a;&#xff01;&#xff01;&#xff01;此文为c语言函数系列的第一篇&#xff0c;全系列字数将达到1w字以上且全为干货内容&#xff0c;请各位仔细阅读并打开编译器运行文章中出现的代码进行试验以确保能理解文章内容i…

JavaFX中的塔防(6)

因此&#xff0c;我们已经在本教程的第6部分中&#xff0c;与此同时&#xff0c;游戏也取得了长足的进步。 在这一部分中&#xff0c;我们最终将添加一个显示得分的图层&#xff0c;已达到目标的敌人数量&#xff0c;启动下一个Wave的按钮以及用于购买新炮塔的资金。 说到钱&am…

教师计算机网络培训工作总结,教师培训工作的自我总结

【导读】教师培训工作的自我总结为好范文网的会员投稿推荐&#xff0c;但愿对你的学习工作带来帮助。教师是一个平凡而又伟大的职业&#xff0c;那教师培训工作总结怎么写呢?下面小编就和大家分享教师培训工作总结&#xff0c;来欣赏一下吧。教师培训工作总结(一)一年来&#…

十一 hashlib模块

# 1、什么叫hash:hash是一种算法&#xff08;3.x里代替了md5模块和sha模块&#xff0c;主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 &#xff0c;MD5 算法&#xff09;&#xff0c;该算法接受传入的内容&#xff0c;经过运算得到一串hash值 # 2、hash值的特点是&#xff1a…

HashMap如何在Java中工作

面试中最常见的问题是“ HashMap如何在Java中工作”&#xff0c;“ HashMap的获取和放置方法如何在内部工作”。 在这里&#xff0c;我试图通过一个简单的示例来解释内部功能。 而不是理论&#xff0c;我们将首先从示例开始&#xff0c;以便您更好地理解&#xff0c;然后我们将…

input上传文件个数控制

HTML: 1 <h3>请上传[2,5]个文件</h3>2 <form action"" enctype"multipart/form-data">3 <input type"file" name"file" multiple"multiple" id"file" onchange"fileCo…

东北农业大计算机排名,黑龙江高校排名更新,东北林大排名第3,东油排名第8...

东北地区的经济发展起步比较早&#xff0c;属于我国的老牌重工业基地&#xff0c;被称为“新中国工业的摇篮”&#xff0c;是我国最重要的经济支柱。这里的高校也因此而受到重视&#xff0c;为日后的发展奠定了扎实的基础&#xff1b;随着国家经济重心的转移&#xff0c;因为地…

150个Java面试问答-最终清单(PDF下载)

我们的Java面试问题和答案集合全都涉及可以在Java面试中使用的不同类型的问题&#xff0c;以使雇主可以测试您在Java和面向对象编程方面的技能。 在以下各节中&#xff0c;我们将讨论有关面向对象编程及其特性的Java面试问题&#xff0c;有关Java及其功能的一般问题&#xff0…

计算机电子电路原理图,简单电路图入门-电路原理图入门知识图解

简单电路图入门-电路原理图入门知识图解电路图的分类简单电路图入门&#xff0c;常遇到的电子电路图有原理图、方框图、装配图和印版图等。1、原理图原理图就是用来体现电子电路的工作原理的一种电路图&#xff0c;又被叫做“电原理图”。这种图由于它直接体现了电子电路的结构…

老是不中,算了算“双色球”和“3D”,全买到底要多少¥¥。。(C 代码)

最近也做发财梦&#xff0c;买了段时间得彩票&#xff0c;不得要领&#xff0c;今天写了两个小程序&#xff0c;算算把所有号码组合都买下到底要多少&#xffe5;&#xffe5;。。还是先贴个规则吧&#xff1b;双色球&#xff1a;从 1~33 中选6个不重复得数值&#xff08;红球&…

pycharm 中 import requests 报错

一 , 使用Pycharm来抓取网页的时候&#xff0c;要导入requests模块&#xff0c;但是在pycharm中 import requests 报错。 原因&#xff1a; python中还没有安装requests库 解决办法&#xff1a; 1.先找到自己python安装目录下的pip 2.在自己的电脑里打开cmd窗口。先点击开始栏&…

dell 计算机硬盘保护,dell台式机硬盘保护 怎样取消

工具/原料十字型螺丝刀一把新台式机硬盘一块方法/步骤1.把新购置的硬盘拆开&#xff0c;以备后面使用&#xff1a;2.拆下机箱的侧面板&#xff0c;注意&#xff0c;侧面板有两颗螺丝固定&#xff0c;需要先卸下&#xff0c;之后向一侧方向拉出侧面板就可以了&#xff0c;拆下侧…

安全建设之平台搭建

一、信息搜集类 基础信息 基础信息搜集包括ip&#xff0c;域名&#xff0c;端口&#xff0c;框架&#xff0c;组件信息。Ip、域名甲方可通过运维同事获取&#xff0c;其他获取方式仁者见仁智者见智。端口&#xff0c;需要我们根据获取的域名、ip进行端口扫描&#xff0c;这里推…