写点什么

第四周笔记

用户头像
willson
关注
发布于: 2020 年 11 月 15 日

原则

灵活运用,而非刻意遵循

1. 基础原则

尽量少的重复代码,低耦合(尽量小的影响),高内聚

模块,可小到一个类,大到一个系统

模块间耦合因素

构建架构时,需要谨慎耦合的因素

  • 模块间调用

  • 模块间传递的数据量

  • 模块间控制

  • 模块间接口复杂度

模块间耦合从弱到强顺序

构建架构或简单的类时,需要根据实际情况尽量契合弱的模块间耦合关系

做到职责分明,简单轻量,尽量少的潜在性的数据流动,尽量少的相互影响,避免牵一发而动全身

  1. 非直接耦合: 相互之间没有直接关系,而是由第三方模块控制和调用

  2. 数据耦合: 通过传递java的内置数据类型通讯

  3. 标记耦合: 都引用了共同的数据结构,并且通过传递该数据结构通讯

  4. 控制耦合: 通过传递开关、标志、名字等控制信息,明显的控制选择另一个模块的功能

  5. 外部耦合: 都访问一个java的内置数据类型的全局变量

  6. 公共耦合: 都访问了一个公共代码块( 全局数据结构、公共通讯区、内存公共覆盖区等)

  7. 内容耦合: 一个模块直接修改另外一个模块的数据。

降低耦合度的方法

  • 少用类继承,多用类接口隐藏实现细节

  • 模块功能尽量单一

  • 拒绝重复代码

  • 尽量不使用全局变量(Android中的全局变量会有一些坑,因为Attach在ClassLoader上的,因此根据不同ROM的优化,可能会在未预料的情况被unload,导致数据丢失)

  • 类成员变量与方法少用public,多用private

  • 尽量不用硬编码(如 字符串放到 res/string.xml,SQL语句做一层基于业务的封装供上层使用)

  • 使用设计模式,尽量让模块间的耦合关系保证在数据耦合或更弱

2. 原则汇总

使用组合而非继承的场景:

优先使用对象组合,而非继承

  • Has-A的关系,而非Is-A的关系

  • 子类的主要目的是拓展父类,而非override或final,如果存在大量这种情况,改用组合

  • 引入工具类,而非继承自工具类

  • 有可能或不确定 子类 有可能被替换为 另外一个类的子类的情况 ( 如果出现这种情况,就需要修改。因此还不如使用 组合,如果有类似需求,再 组合如新的对象,进行拓展即可)

继承需要注意

当已经选择使用继承时,需要注意

  • 实现抽象方法,拓展新的特性方法,尽量少的重载父类非抽象方法

  • 重载父类非抽象方法时: 方法前置条件(方法形参)要比父类方法更宽松,方法后置条件(方法返回值)要比父类更严格



用户头像

willson

关注

还未添加个人签名 2018.03.08 加入

还未添加个人简介

评论 (1 条评论)

发布
用户头像
这好像是第三周的课啊😀
2020 年 11 月 16 日 18:47
回复
没有更多了
第四周笔记