从分析到设计

用例模型

组成

参与者
用例(取名:短小精悍的动名词,如“取钱”、“修改密码)
用例描述 (作为领域模型的输入、设计的输入、开发的输入…)
系统边界
系统顺序图
操作契约

参与者

位于系统外部并与系统进行交互的一类事物(人,物和其他子系统等)


image.png
参与者的三类

主要参与者:通过该系统来实现自己的需求如Pos系统的收费员
协助性参与者:提供支持如第三方接口,POS系统的信用卡支付的授权认证服务
幕后参与者:对系统功能感兴趣,但不是很强烈如POS系统的政府税收代理人员

用例

用例是一系列动作或处理,且能为参与者产生有价值的结果

用例描述的三种详细程度

简短格式:主事件流
随意的:写到哪是哪里
正式的: 按照指定格式来写

定义“合适“的用例

①用例是否描述了应该做什么,而不是如何做?
②用例的描述是否采取了参与者的视点?
③用例是否对参与者有价值?
④用例描述的时间流是否是一个完整场景?
⑤是否所有的参与者、用例都有相应的关联用例或关联参与者?

系统边界

image.png

用例描述

关注参与者的目标,描述事务的本质。与界面无关,与实现机制无关。
用词简洁
“黑盒”的用例描述:描述做什么功能,而不是该功能是怎么实现的。
从参与者及其目标的角度进行描述:询问他们的目标,典型场景,聚焦”产生有价值的结果”

示例
image.png

契约式设计

问题的引入

image.png

名词解释

客户,客户端:需要服务的一方
服务端,服务器:提供服务的一方

一份契约承载着客户端和服务端的义务

客户端:只有满足服务端的前置条件下,才能使用服务端提供的服务
服务端:服务端结果服务后,必须满足后置条件。
如顾客到商店买食品。必须是真钱,不是假币。食品必须卫生、安全、符合
质量要求

实现:断言

单个操作:每个功能定义一个前置条件和一个后置条件
image.png
类不变量:类的所有操作都需要遵守
image.png

操作契约

强调一些动作的开始的前置条件和结束的后置条件。

示例
image.png
描述后置条件的策略

instance creation and deletion
attribute modification
associations formed and broken

设计

image.png

软件架构

定义

组织类以形成模块,分成,子系统,命令空间等

设计方法:分层法

层:表示一定规模的结构元素,来完成特定功能。
注:在“分”的同时,也要考虑“合”

分层架构的优点

各层都容易被替换
较低层次包含更多的操作细节,容易成为可重用的构件
每层都容易分布部署与连接

分层时考虑的问题

服务是放在高层还是底层
服务是作为应用专门的,还是通用的

面向对象设计

面向对象设计的关注点

主要工作和业务逻辑相关,不关注用户界面和数据存储。

设计思想的来源

软件设计最新的概念
同学们要经常去关注,比如 www.csdn.net , 一些开源网站等
研习针对大规模/小规模问题的“最佳实践”解决方案
教材、论文记录的一些方法
在不同上下文中重用——不要从头开始设计解决方案
注设计还需要一点灵感

大规模系统设计遇到的问题

如何定义领域层对象与子系统之间的协作
如何定义UI对象到领域层对象之间的协作?
如何设计与实现“向上”的协作?

设计的总体思路

标识职责 responsibilities,并把它们分配给不同的类
1 职责描述是一种抽象,粒度大小不一
软件对象只有方法 methods,没有职责
从职责到对象方法的转换比如,“负责永久存储”,粒度太大,比如“负责计算税费” ,粒度要好一些
2 职责驱动的设计 RDD,对象设计时可以问这样的问题
这个对象有哪些职责?
这个对象与哪个对象协作?

如何分配职责

GRASP是很好的指导原则:通用的职责分配软件原则(模式)GRASP General Responsibility Assignment Software Principles(patterns)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容

  • 第八章 系统分析与设计方法 8.1 定义问题与归结模型 定义问题的过程包括:理解真实世界中的问题和用户的额需要,并...
    步积阅读 3,932评论 0 12
  • 1.埋点是做什么的 2.如何进行埋点 3.埋点方案的设计 近期常被问到这个问题,我担心我的答案会将一些天真烂漫的孩...
    lxg阅读 2,012评论 0 1
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,094评论 1 32
  • 在mac下使用maven对Scala代码进行打包。 mac编程环境: 安装Scala (官网下载安装,tarbal...
    小甜瓜Melon阅读 4,002评论 0 3
  • 给在深夜里的自己一个拥抱。我相信很多人都曾在自己最无助的时候自己蜷缩到一起,给自己一个拥抱。那是一种支持,自身的正...
    一个疯狂的小钕子阅读 161评论 0 0