软件设计---高层设计(一):共性可变性分析和分析矩阵

软件开发中最大的问题之一为:处理问题域中的变化。初次拿到软件需求,看似有一定规律,但也存在各种特殊情况。怎样发现共性,及其变化,Alan在他的书中(design patterns explained)中给出了两种方法:共性可变性分析,和需求知矩阵。

共性可变性分析

先找出概念,及它们的各种变化。 然后分析概念之间的关系,通过从大到小的顺序。背景法。如果概念1使用了概念2,则概念1是背景,应该先分析概念1。相当于先搞出框架,然后填东西,这样会更高效一些。

将概念定义为接口,而它们的变化则定义为具体实现类。

几乎所有的问题都可以这样进行分析。

比如,对于一个发布文章到博客网站上的需求:

  • 能够发布html格式的文章
  • markdown 格式的文章
  • 能够发布到wordpress, cnblogs, blogger, chinaunix, github
  • 文章中可以有图片

其中概念为: 文章, 发布器 注: 怎样寻找概念: 1. 名词。 2. 动词再个"er",将它变为名词。 其中文章的变化为: html格式,markdown格式 发布器的变化为 wordpress发布器, cnblogs发布器, blogger发布器。

只有这两个概念。 再来看两个概念间的联系。发布器会到文章,因此我们先来分析发布器。文章可以作为发布器的一个参数。

要发布一篇文章到某个目标,先创建一个目标的发布器,再创建文章,然后将文章传给发布器。

发布器和文章还可能有一处关系: 即存在第三个概念,将二者作为参数,进行发布。这种其实跟前者只有略微差别,在实际中可不计较二者的微小差异。不要钻牛角尖。

需求矩阵

使用需求矩阵,可以更加明确地找出概念及变化,尤其是对于复杂的需求。

先在需求中找出需要处理的情况。然后对每种情况的,从需求中找出其中的概念。每拿到一个具体的条目,就找出可能表示它的通用概念,然后第一列表示概念,第二列表示第一种情况。每行表示一个概念及其变化。当处理完第一种情况后,继续处理第二种情况,同样对于每个条目,如果它的概念已经存在,则直接填在相应行,否则就扩展矩阵,添加一行用于表示这个新的概念。

最终完成后,每一行可以通过一个stratege模式处理,然后通过 abstract factory模式为每一种情况(每一列)创建处理对象。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏小樱的经验随笔

hihoCoder #1053 : 居民迁移(贪心,二分搜索,google在线技术笔试模拟)

#1053 : 居民迁移 时间限制:3000ms 单点时限:1000ms 内存限制:256MB 描述 公元2411年,人类开始在地球以外的行星建立居住点。在第1...

3537
来自专栏我是攻城师

Lucene暴走之巧用内存倒排索引高效识别垃圾数据

26610
来自专栏https://www.cnblogs.com/L

【自然语言处理篇】--聊天机器人从初始到应用

维基百科中的机器人是指主要用于协助编者执行大量自动化、高速或机械式、繁琐的编辑工作的计算机程序或脚本及其所登录的帐户。

812
来自专栏大数据挖掘DT机器学习

Python股票数据分析

python版本:3.4 最近在学习基于python的股票数据分析,其中主要用到了tushare和seaborn。tushare是一款财经类数据接口包,国内的...

3987
来自专栏数据结构与算法

BZOJ1096: [ZJOI2007]仓库建设(dp+斜率优化)

Description   L公司有N个工厂,由高到底分布在一座山上。如图所示,工厂1在山顶,工厂N在山脚。由于这座山处于高原内 陆地区(干燥少雨),L公司一...

3405
来自专栏数据小魔方

R语言可视化——用ggplot构造期待已久的雷达图

之前一直苦恼于ggplot函数无法制作雷达图,心想着既然饼图可以通过柱形图+极坐标模拟出来,为啥雷达图不行。 我尝试着用折线图+极坐标来模拟雷达图(之前在制作饼...

2686
来自专栏CDA数据分析师

手把手教你用Python分析豆瓣电影——以《我不是药神》《邪不压正》为例

《我不是药神》是由文牧野执导,宁浩、徐峥共同监制的剧情片,徐峥、周一围、王传君、谭卓、章宇、杨新鸣等主演 。影片讲述了神油店老板程勇从一个交不起房租的男性保健品...

1253
来自专栏武军超python专栏

2018年8月26日python常识和各大语言发展史

今天遇到的新单词: precision  n精确度 generator n发电机,生产者,生成器

774
来自专栏java工会

科大讯飞人工智能方向的一次面试经历

就在上个星期五(2017年12月8号),我去了科大讯飞面试Java智能语音这一块。

662
来自专栏信数据得永生

JavaScript 编程精解 中文第三版 七、项目:机器人

3186

扫码关注云+社区