android中MVC MVP MVVM三种架构对比

一、MVC

 model层:数据模型,通常是bean对象

 view层:layout布局,activity对象

 controller层:activity对象

优点:结构简单,灵活

缺点:随着业务的增加Activity会变的臃肿,因为activity中既要处理业务逻辑又要更新view,不符合单一职责设计思想,耦合度高,扩展性、可重用性差。

使用场景:业务简单的小型项目

二、MVP

 model层:数据模型,通常是bean对象

 view层:layout布局,activity对象

 presenter层:presenter接口,及实现类,View层与Model层的桥梁并对业务逻辑进行处理

mvp架构由mvc架构发展而来,p层将业务逻辑处理从activity中抽离出来,实现了view层与model层的完全解耦,但view层和presenter层还是有耦合(p层需要持有v层的引用,来更新view)。

优点:分层清晰,耦合降低。

缺点:需要定义和实现大量接口,使用复杂度高

使用场景:大型项目,业务很重,开发人员多

三、MVVM

 

model层:数据模型,通常是bean对象

view层:layout布局,activity对象

viewModel:连接 View 与 Model 的中间桥梁,ViewModel 与 Model 直接交互,通过DataBinding将数据变化反应给View

优点:进一步解耦view与viewModel层(viewmodel无需持有view层对象,通过DataBinding数据双向绑定)

缺点:需要使用DataBinding,增加了编译时间;

           不易于调试和追踪bug。

使用场景:界面UI更新频繁的项目,因为模块间解耦,修改起来更容易

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值