6.5 开始进入设计 … Transition to Design
开始进入设计 … Transition to Design
从需求分析到设计
逻辑架构与子系统 Logical Architecture and sub-system
5.1 向设计过程切换 Transition to Design
需求与领域分析阶段During requirements and domain analysis work
做正确的事情 “Do the right thing”
理解领域问题 Understand the domain
澄清并记录约束和需求 Clarify and record the constraints and requirements
本质上,暂不考虑设计,集中在理解问题
设计阶段 During design work
正确地做事情 “Do the thing right”
创建设计模型,以便构建系统 Create a design model that can be used to build the system
满足领域约束 Meet the domain constraints
两类主要的模型: 交互图 Interaction diagrams 设计类图 Design class diagrams
设计的输入
系 统 操 作 System Operations
或者操作契约
迭代
每次迭代,都存在需求 到设计的过程
遇到需求的变化,应当 “拥抱”而不是“回避”
设计的结果
设计一个方案,展示系 统是如何实现需求
5.2 逻辑架构、软件架构
什么是架构 What is Architecture?(有的教材翻译成“结构”)
架构是关于如何组织软件系统的一系列重大决策
An architecture is the set of significant decisions about the organization of a software system
如何选择组成系统的结构元素及其接口
这些结构元素相互协作时的行为规范
这些结构元素如何组合成逐渐变大的子系统
可以参考的架构风格 architectural style,以便指导如何组织这些结构元素、定义它 们的接口、协作、以及组合成子系统的过程
架构的另外一种说法: Logical Architecture、Software Architecture
大规模组织类,以便形成模块、分层、子系统、命名空间等
不同于部署架构 Deployment Architecture 定义这些结构元素分布在不同的物理设备上
可能会影响逻 辑架构的因素, 还包括: 补充规 格说明中约束 、非功能性需 求等
5.3 逻辑架构设计方法 – 分层法
分层 System Partitioning
“分而治之”
标识一定规模的结构元素 large-scale elements (LSEs)
层Layers: 粗粒度地组织结构元素,考虑内聚性,完成特定功能
Coarsegrained grouping of architectural elements cohesively responsible for a specific aspect
子系统 Subsystems
模块 Modules
接口
结构元素之间的协作
在开发的过程中,上述各部分是会变化的
在“分”的同时,要考虑“合”
5.4 分层架构的优点
优点
各层都容易被替换 Layers can be easily replaced
较低层次包含更多的操作细节,容易成为可重用的构件
每层都容易分布部署与连接
分层时考虑的问题 Separation of concerns
服务是放在高层还是底层 High-level vs. low-level services
服务是作为应用专门的,还是通用的 Application specific vs. general services
5.5 分层架构示例
物联网大数据平台TIZA STAR架构http://mt.sohu.com/20161024/n471123659.shtml
6.5 开始进入设计 … Transition to Design的更多相关文章
- 什么是领域驱动设计(Domain Driven Design)?
本文是从 What is Domain Driven Design? 这篇文章翻译而来. ”…在很多领域,专家的作用体现在他们的专业知识上而不是智力上.“ -- Don Reinertsen 领域驱动 ...
- 企业级的响应式设计(Responsive design at enterprise level)译
导言 响应式设计是现在人们谈论的热点,但如何部署,特别是在有多种设备的大型项目中如何组织响应式设计,响应式设计和可伸缩性(Scalable)有什么区别?这都是需要解决的难题. 优化用户经验——Opti ...
- 领域驱动设计(Domain Driven Design)参考架构详解
摘要 本文将介绍领域驱动设计(Domain Driven Design)的官方参考架构,该架构分成了Interfaces.Applications和Domain三层以及包含各类基础设施的Infrast ...
- 领域驱动设计(DDD:Domain-Driven Design)
领域驱动设计(DDD:Domain-Driven Design) Eric Evans的"Domain-Driven Design领域驱动设计"简称DDD,Evans DDD是一套 ...
- [转载]领域驱动设计(Domain Driven Design)参考架构详解
摘要 本文将介绍领域驱动设计(Domain Driven Design)的官方参考架构,该架构分成了Interfaces.Applications和Domain三层以及包含各类基础设施的Infrast ...
- 洛谷 P3650 [USACO1.3]滑雪课程设计Ski Course Design
P3650 [USACO1.3]滑雪课程设计Ski Course Design 题目描述 农民约翰的农场里有N座山峰(1<=N<=1000),每座山都有一个在0到100之间的整数的海拔高度 ...
- LeetCode 622:设计循环队列 Design Circular Queue
LeetCode 622:设计循环队列 Design Circular Queue 首先来看看队列这种数据结构: 队列:先入先出的数据结构 在 FIFO 数据结构中,将首先处理添加到队列中的第一个元素 ...
- 算法、数据结构、与设计模式等在游戏开发中的运用 (一):单例设计(Singleton Design)
算法.数据结构.与设计模式等在游戏开发中的运用 (一):单例设计(Singleton Design) 作者: Compasslg 李涵威 1. 什么是单例设计(Singleton Design) 在学 ...
- 设计系统(Design System),设计和开发之间的“DevOps”
最近,我们网站的上新增了几个新功能,比如通过导航栏的QR Code可以下载App:通过Carousel的方式,显示多条信息. 以往这样的功能可能需要2-3个Sprints完成,但是现在这些功能都是在一 ...
随机推荐
- HDU1285 确定比赛问题【拓扑排序+优先队列】
题目 有N个比赛队(1<=N<=500),编号依次为1,2,3,....,N进行比赛,比赛结束后,裁判委员会要将所有参赛队伍从前往后依次排名,但现在裁判委员会不能直接获得每个队的比赛成绩, ...
- 深度学习课程笔记(五)Ensemble
深度学习课程笔记(五)Ensemble 2017.10.06 材料来自: 首先提到的是 Bagging 的方法: 我们可以利用这里的 Bagging 的方法,结合多个强分类器,来提升总的结果.例如: ...
- (转) Learning Deep Learning with Keras
Learning Deep Learning with Keras Piotr Migdał - blog Projects Articles Publications Resume About Ph ...
- 给大家分享两套WordPress收费主题
主题一:No.7 – 极简 by 大当家 1.主题网址:http://qzhai.net/2016-03-546.html 2.主题预览:http://qzhai.net/000/?theme=No. ...
- SAP 供应商/客户的冻结及其删除操作
SAP 供应商/客户的冻结及其删除操作 在SAP中,有所谓的财务供应商(Tcode:FK01)和后勤供应商(Tcode:XK01),供应商和客户主数据包括一般数据/公司代码数据/采购组织|销售范围三方 ...
- Centos6.5 搭建LAMP环境
1.Centos6.5 处于对安全的考虑,严格控制网络的进去.所以安装 Apache 或 MySQL 的时候,需要开放 80 或 3306 端口 首先,执行如下命令查看当前防火墙开放了哪些端口: [ ...
- MD5加密与Hash加密
一.Md5加密 MD5算法具有以下特点: 1.压缩性:任意长度的数据,算出的MD5值长度都是固定的. 2.容易计算:从原数据计算出MD5值很容易. 3.抗修改性:对原数据进行任何改动,哪怕只修改1个字 ...
- tf一些函数
1. tf.reduce_mean(a) : 求平均值 2. tf.truncated_normal([3,2],stddev=0.1) : 从正态分布中输出随机值,标准差为0,1,构造矩阵为3*2的 ...
- MySQL学习(十四)
utf8的bom问题 在xp下,用记事本创建utf8文件的时候,前面多了3个字节,这3个字节不用来显示,是用来辨识编码用的,EF BB BF告诉记事本,这是utf8编码. 存储引擎和事务简单介绍 引擎 ...
- (转)C# Xml进行序列化与反序列化
---------------------------------------------------------------文章1---------------------------------- ...