清华《软件工程》10.1 、10.2、10.4节
10.1 面向对象分析
面向对象分析的思路来源
面向对象分析中支持的结构
一般—特殊结构(表继承关系
一般—特殊结构 是将类组织成基于继承关系的分类层次结构,自顶向下是从一般到特殊的类,即从父类到子类
整体—部分结构(表组合关系
整体—部分结构 是描述对象间的组合关系,eg:一个交通灯由灯组、支撑杆和位置三个对象构成。
服务建模
面向对象分析方法
面向对象分析的局限性
我们想通过面向对象的思路更早的进入分析和设计的环节,往往会因为分析阶段的概念和设计阶段的概念无法对齐而无法实现。
总结
我们在面向对象中最有用的对象就是对领域实体对象的建模
10.2 CRC卡片分拣法
识别类的方法
设计系统时,需要识别类、类的职责、类之间的交互行为。
CRC卡片介绍
其三个要素分别为:类(class)、类职责定义(responsibilities)、交互协作关系定义(collaborations)
先尝试用名词提取出所有可能的类,再逐一筛选,对象可以是如下存在:
如何筛选类
识别类
识别类的功能职责
职责关乎行为动作,因此是问题描述中的动词。
识别类交互协作关系
就是识别对象及其信息交互,目的并不是为了写出所有场景,而是对类和职责定义进行精化。
一个CRC卡片如下:
10.4 类图建模
什么是类
类是具有 相同性质,相同行为,相同的对象关系,相同的语义 的对象集合。
什么是对象
属性要注意封装,外部访问时,需要调用才能获得。
类属性定义
在为类选取属性时,要求属性能够描述并区分该类对象,每条属性的格式是:[可见性]名称 [:类型] [多样性] [= 初值] [{约束}]
公有属性 +表示,私有属性 -表示,受保护的属性 #表示,可见性对同包 ~ 表示
类关系
UML中,有以下几种类型的关系:关联关系、聚合与组合关系、泛化关系(继承关系)、依赖关系、实现关系。
关联关系的多样性/维度定义 方法:类对象的存在可选择时,我们可以开始时定义为0或1,有且仅有一个的时候只能是1,当可以是没有或者多个的时候为0...*,当必须有而且可以有多个的时候为1...*,也可以定义一个取值范围。
关联类
限定关联
在进行关联建模的时候,一个好的关联的定义是1对多的,因此通过限定符,可以把原本N对N的关联降为1对N。限定符不需要初始值。
聚合与组合关系
eg:一个窗口和其按钮是组合关系,一个元素集合与其元素是聚合关系 ,聚合与组合主要是看其产生和消亡的周期是否同步,组合关系比继承关系应用起来更加方便。
继承/泛化关系
自顶向下 是由于某个事物本身可以分为好几种类型,例如车可以分为电动车,公交车...
自底向上 是由于某两个事物的属性或方法是相同的,那么就可以把这些属性和方法作为一个父类