位置: 编程技术 - 正文

Android与设计模式:用单一职责原则为Activity解耦(android设计模式的应用场景)

编辑:rootadmin
一、什么是单一职责原则

推荐整理分享Android与设计模式:用单一职责原则为Activity解耦(android设计模式的应用场景),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:android中的设计模式,android中的设计模式,android设计app,android中的设计模式,android设计模式与最佳实践,android设计模式书籍,android设计模式与最佳实践,android设计模式总结,内容如对您有帮助,希望把文章链接给更多的朋友!

单一职责原则(SRP:Single responsibility principle)又称单一功能原则,其定义为:一个类,应该只有一个可以导致变化的原因。光看概念会让人很头疼,我先讲点小例子吧:

二、单一职责原则能解决什么问题

回顾我们的 Android 开发经历,很多人都会发现 Activity 类中的代码总会不知不觉地变得很多,这会让读我们代码的人非常痛苦。而造成这种情况的其中一个原因是:Activity 中需要与用户进行大量的交互,用户的操作会改变 Activity 当前显示的界面元素/对应的信息,所以我们总会把 Model、View、点击事件等等……操作全都放到了 Activiy 中,但这样存在一个很严重的问题,无脑地为 Activity 添加代码,势必让 Activity 变得臃肿,结构混乱,职责模糊,特别是之前负责该项目的工程师已经离职,新入职的工程师需要重构该 Activity 时,必将痛不欲生。

那么我们要怎样为 Activity 解耦呢?我先通过一个小 Demo 以单一职责原则的思想为 Activity 解耦,详情如下:

在 Demo 里我们可以看到,所有相关的操作都在 Activity 里进行,要知道,这还只是一个非常简单的页面,可以说完全不存在业务逻辑。换成一个业务逻辑复杂的页面,这还用玩?接下来换一个思路,用 MVP 模式解耦:

Android与设计模式:用单一职责原则为Activity解耦(android设计模式的应用场景)

进行这样的重构之后,Activity 类发生了什么变化呢?我们先回想下 Android SDK 对 Activity 的定义吧:

An activity is a single, focused thing that the user can do. Almost all activities interact with the user, so the Activity class takes care of creating a window for you in which you can place your UI with {@link #setContentView}. While activities are often presented to the user as full-screen windows, they can also be used in other ways: as floating windows (via a theme with {@link android.R.attr#windowIsFloating} set) or embedded inside of another activity (using {@link ActivityGroup}).

简单翻译下:Activity 象征用户能完成的一件事,大部分 Activity 用于和用户进行交互,在其中放置我们的 UI。

也就是说,Google 官方认为 Activity 的职责是:呈现 UI,与用户交互。

那么之前的代码很显然违反了单一职责原则了,因为在 Activity 中不但要进行数据的请求和更新、根据用户的交互/更新的数据去修改 View。那么新代码让 Activity 发生了什么改变呢?第一、数据的请求/更新由 Presenter 处理,不需要经过 Activity 去请求/更新;第二、View 相关的逻辑(如:修改)由 IView 接口提供,Activity 只需要完成具体实现。

三、遵循单一职责原则有什么好处

那么进行这样的重构有什么好处呢?我相信看了示例之后,大家心里多少会有些说不清、道不明的触动,特别是回忆起过去写的一些结构糟糕的代码时触动会更深些。实际上,我个人认为设计模式中的思想和生活中高效组织、完成工作的思想都是一致的,因为所谓设计模式,本身就是前人对写代码的经验总结,其目的就在于:提高效率,便于维护,让代码易读,易拓展等等……回顾生活,我们要想让一个团队/组织/公司/企业高效运作,那么这个群体就得根据实际划分部门 —> 确立部门沟通规范 —> 部门内再次进行团队职责细分(例如 UI 部门分为:视觉设计、交互设计等等……) —> 部门成员明确分工,尽可能让整个群体结构呈现为模块化、低耦合、高内聚、职责区分清晰的结构。

而单一职责原则体现的也是这样的思想,一个类,应该只受其最根本的抽象逻辑影响,类内的具体变化都应该来自于该抽象逻辑,我们说单一职责,我认为其含义不在于一个类做一件事,而在于一个类就是一个抽象群体,抽象群体具有自身的属性和职责,它的职责可能需要它做很多事,但它的职责始终唯一。

进行这样的重构之后我们可以把类内不属于它的逻辑剥离出去,让类遵循它的抽象逻辑,而不需要为其他不属于它的职责增加代码。

Android集成讯飞SDK实现语音拨号、语音导航、语音启动应用 转载请注明出处:周木水的CSDN博客

Gallery图片浏览 原文:Gallery图片浏览源代码下载地址:

迄今最好的Http请求框架 本文原创,转载请注明链接

标签: android设计模式的应用场景

本文链接地址:https://www.jiuchutong.com/biancheng/378185.html 转载请保留说明!

上一篇:关于在Android工程中新添加了一个Activity 而程序崩溃的问题(关于android工程中的assets目录的正确说法)

下一篇:Android集成讯飞SDK实现语音拨号、语音导航、语音启动应用(讯飞src)

  • 全成本核算优缺点
  • 收到银行存兑汇票
  • 公司固定资产抵税
  • 土增清算尾盘销售
  • 火车票丢失可以抵扣进项税额
  • 个税专项扣除中途贷款改租房
  • 私营小微企业可以贷款吗
  • 汇总记账凭证会计核算形式
  • 私房装修费能在公司报销吗
  • 会计期末要做的事情
  • 货款现金收据可以做账吗
  • 公司清算 债权
  • 股东变动及股东情况章节
  • 跨年度取得增值税发票
  • 开增值税专票交多少税费
  • 最近偷税女星都有谁
  • 财务费用结转本年利润借贷方怎么记
  • 汇算清缴后需要退税如何操作?
  • 税控盘服务费抵减有效期几年
  • 非货币性资产交换差额计入什么科目
  • 债券返售
  • 个体工商户需要办公户吗
  • 微信聊天记录备份和恢复
  • PHP:curl_multi_getcontent()的用法_cURL函数
  • 其他业务成本主要有哪些
  • 嵌套if怎么用
  • 发票开出后只收到部分款怎么处理?
  • cuda completed with errors
  • 没有购入发票可以开出发票
  • 模态框无法弹出
  • Java8 Stream流Collectors.toMap当key重复时报异常(IllegalStateException)
  • uniapp官方教程
  • 免费开源的图片app
  • vue面试题视频
  • 520要来了要吵架的赶紧
  • 班迪录屏软件录制框怎样在ppt上一直指定
  • 云质信息
  • Using Visual Leak Detector
  • python del语法
  • 双重数组
  • 银行结算方式有哪几种方式?其具体内容是什么?
  • 公司购车需要什么材料
  • 企业所得税营业成本包括管理费用吗
  • 应交税费余额是什么意思
  • 印花税计入什么会计分录
  • 公司办公室买的茶叶怎么入账
  • 暂估入账的固定资产
  • 延缓缴纳的企业所得税怎么做账
  • 化肥贸易行业
  • 收到增值税专用发票是进项还是销项
  • 建筑业发票的相关要求
  • 存货出售,资产减值损失如何处理
  • 营改增之后账务怎么处理
  • 购买电脑增值税税率是多少
  • 企业什么情形必须签无固定期限合同
  • 红字冲销凭证怎么登明细账
  • ubuntu20.04.2安装
  • 如何打开mac系统终端
  • win8怎么打开系统设置
  • Win10 Mobile Redstone版本号确定为Build 11082明年发布
  • win10系统的电脑
  • windows vhd
  • win10 ug
  • 简单总结译码器和数据选择器的作用
  • fragment的replace方法
  • 网页设计中css样式有何用途
  • 列表框代码
  • jquery网站开发
  • 详细介绍8款超跑车
  • androidcontext传值
  • JQUERY的AJAX请求缓存里的数据问题处理
  • 新浪微博手机客户端下载
  • adb查看ip地址
  • js下拉菜单的制作方法
  • 福建省电子税务局官网登录入口
  • 东莞网上办税服务厅
  • 保定市国税局车管所所长
  • 江西省税务局官网
  • 发票明细怎么导入开票系统里
  • 消费税的纳税人是买方还是卖方
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设