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

软件开发中最大的问题之一为:处理问题域中的变化。初次拿到软件需求,看似有一定规律,但也存在各种特殊情况。怎样发现共性,及其变化,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 条评论
登录 后参与评论

相关文章

来自专栏机器人网

工业机器人控制系统组成及典型结构

一、工业机器人控制系统所要达到的功能 机器人控制系统是机器人的重要组成部分,用于对操作机的控制,以完成特定的工作任务,其基本功能如下: 1、记忆功能:存储作业顺...

4104
来自专栏BestSDK

Hexagon DSP 发布SDK 3.3.2,打造全新神经网络库

将推理、场景分类、图像处理和视频回放增强之类的工作负载放到边缘设备(如智能手机)的CPU和GPU进行处理,会耗尽运行周期并缩短电池使用寿命。DSP编程越方便,您...

5366
来自专栏服务端技术杂谈

程序员工作久了基础更重要

工作一段时间会遇到一个瓶颈期,会考虑未来1到2年的发展和方向问题,之前的方式是通过不停的学习新的框架或者解决方案来调整。 比如写服务端代码期间会去学习TDD,D...

29710
来自专栏杨建荣的学习笔记

运维平台中的业务树初版设计

资源服务的一个基本单元是服务器,可以是虚拟机,物理机,也可以是docker等。这是最底层的资源服务。

1283
来自专栏高性能服务器开发

10 十万在线的WebGame的数据库设计思路

在线人数预估: 在项目设计之前,需要先对运营后的服务器人数做一下预估,预计激活人数300w,活跃人数40w,同时在线10w。而服务器的设计极限则在激活人数50...

1341
来自专栏BestSDK

Google发布Nearby Connections API 2.0版本,可拓展本地信息和数据分享

关注过 I/O 2017 开发者大会的网友们,或许还记得 Google 提到过的“情境应用体验”(Contextual App Experiences)。这组 ...

3084
来自专栏每日一篇技术文章

教你如何制作APP 赚钱

1.识别图片中多张人脸的年龄 2.有分享功能 3.用评分功能 4.投放Google广告

7561
来自专栏流柯技术学院

如何应用性能测试常用计算公式

性能测试中有很多非常重要的概念,如吞吐量、最大并发用户数、最大在线用户数等。有很多读者也非常关心,如何针对自身的系统确定当前系统,在什么情况下就可以满足系统吞吐...

2331
来自专栏IT大咖说

新一代CMDB模型构建指南

摘要 今天我为大家带来的分享主题是新一代CMDB模型的构建指南,主要分为四大部分。 困境:当前CMDB模型面临的普遍困境 很多CMDB建设前期做得风风火火,而后...

4555
来自专栏Android 开发者

app 里的 A/B 测试简介

4503

扫码关注云+社区