软件工程之结构化设计篇_需求分析、软件结构、类与接口设计-程序员宅基地

技术标签: 软件工程  

1 软件设计的基本概念

完成了需求分析,回答了软件系统能“做什么”的问题后,软件的生命周期就进入了设计阶段。软件设计阶段,研发人员将集中精力研究如何把需求规格说明书里归纳的分析模型转换成功可行的设计模型,将解决方案记录到相关的设计文档中。软件设计是回答“怎么做”才能实现软件系统的问题。即把软件系统能做什么的逻辑模型转换成怎么做的物理模型。
软件设计在开发中处于核心地位。

1.1 软件设计的意义和目标

软件设计是保证质量的关键步骤,提供了可以用于评估质量的软件表示,是我们能够将用户需求准确转化为软件产品或系统的唯一方法,它也是一个迭代的过程,通过设计过程,需求被变换为用于构建软件的蓝图。

1.2 软件设计的原则

1 模块化

		模块的公共属性:
		1、每个模块都有输入、输出的接口,接口都指向相同的调用者。
		2、每个模块都具有特定的逻辑功能,完成一定的任务。
		3、模块的逻辑功能由一段可运行的程序来实现
		4、模块还用有属于自己的内部数据。
		注意:
		1、模块的规模要适中
		2、提高模块的独立性
		3、提高模块的内聚程度
		4、加强模块的保护性

2 抽象

3 逐步求精

4 信息隐藏

5 复用性设计

6 灵活性设计

	1 降低耦合并提高内聚
	2 建立抽象
	3 不要将代码写死
	4 抛出异常
	5 使用并创建可复用的代码

1.3 软件设计的分类

1 从活动任务分类
软件设计是对软件需求进行数据设计、体系结构设计、接口设计、构件设计和部署设计
2 从工程管理分类
软件设计分为概要设计(总体设计)和详细设计。前期进行概要设计,得到软件系统的基本框架,后期进行详细设计,明确系统内部的实现细节。

2 数据库结构设计

数据库结构设计包括概念结构设计、逻辑结构设计和物理结构设计

3 用户界面设计

3.1、设计驱动开发

3.2、目标用户群体

3.3、简洁与清晰

3.4、实现模型与心智模型

3.5、设计的规范性

3.6、设计的可用性与易用性

3.7、设计的一致性

3.8、设计的容错性

4、体系结构设计

4.1 表示软件结构的图形工具

1、层次图和HIPO图
2、结构图

4.2 面向数据流的设计方法

1、变换型数据流
2、事务性数据流

4.3 面向数据结构的设计方法

Jackson方法和Warnier方法,
Jackson方法把数据结构分为3种基本类型:顺序型结构,选择型结构,循环型结构。

5、接口设计

5.1 接口设计包括:用户接口、外部接口、内部接口。

5.2 界面设计

1、3个黄金原则:

  • 置用户于控制之下。
  • 减少用户的记忆负担
  • 保持界面一致
    2、核心活动
  • 创建系统功能的外部模型
  • 确定为此完成此系统功能的人和计算机应分别完成的任务
  • 考虑界面设计种的典型问题
  • 借助CASE工具构造界面原型
  • 实现设计模型
  • 评估界面质量

3、4个模型

  • 由软件工程师创建的设计模型
  • 由人机工程师(或软件工程师)创建的用户模型
  • 终端用户对未来系统的假想
  • 系统实现后得到的系统映像

4、界面设计考虑4个问题

  • 系统响应时间
  • 用户求助机制
  • 出错信息
  • 命令方式

6、数据设计

两个部分:

  • 程序级的数据结构设计
  • 应用级的数据库设计

数据库的主要特点:

  • 可以实现数据共享
  • 减少数据的冗余度
  • 数据具有独立性
  • 可以实现数据集中控制
  • 数据具有一致性和可维护性,以确保数据的安全性和可靠性
  • 出现故障可以恢复

基本结构分为三个层次:1、物理数据层;2、概念数据层;3、逻辑数据层

数据库不同层次之间的联系的通过映射进行转换的。
5个步骤:
1、需求分析
2、概念设计
3、逻辑设计
4、物理设计
5、验证设计

数据库常用的存取方法如下:
1、索引方法
2、聚簇索引方法
3、HASH方法

7、过程设计

7.1 用到的工具

  • 程序流程图
    优势:简单,结构清晰,逻辑性强,便于描述,容易理解
    劣势:不利于逐步求精,箭头随意移动,与结构化程序设计精神违背

  • N-S图(合图)
    特点:不允许随意控制转移,有利于严格的结构化程序设计,可以很方便确定一个个特定的控制结构的作用域,以及局部数据和全局数据的作用域,可以很方便地表示嵌套关系以及模块之间的层次结构

  • PAD图(问题分析图)
    特点:自左向右,自上而下,结构清晰,层次分明,只能用于结构化的程序设计,不仅可以表示程序逻辑,还能表示数据结构。

  • 过程设计语言(PDL),伪代码
    特点:关键字的固定语法,自然语言的自由语法,数据说明的手段,模块定义和调用的技术。
    优点:可以作为注释直接写在源程序中间,可以普通的编辑器编写,如果有自动处理程序,可以自动由PDL生成程序代码。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/yangzijiangtou/article/details/127082862

智能推荐

蓝凌EIS智慧协同平台saveImg接口存在任意文件上传漏洞_蓝凌eis智慧协同平台文件上传漏洞-程序员宅基地

文章浏览阅读979次。蓝凌智慧协同平台eis集合了非常丰富的模块,满足组织企业在知识、协同、项目管理系统建设等需求。_蓝凌eis智慧协同平台文件上传漏洞

LLaVA-1.5-程序员宅基地

文章浏览阅读193次。与InstructBLIP或Qwen-VL在数亿甚至数十几亿的图像文本配对数据上训练的、专门设计的视觉重新采样器相比,LLaVA用的是最简单的LMM架构设计,只需要在600K个图像-文本对上,训练一个简单的完全连接映射层即可。结果表明,LLaVA-1.5不仅可以使用更少的预训练和指令微调数据,而且还可以利用最简单的架构、学术计算和公共数据集来实现最佳的性能——在12个基准中的11个上取得了SOTA。为了解决这个问题,研究人员建议在VQA问题的末尾,添加一个可以明确输出格式的提示,进而让模型生成简短回答。

ORACLE基本数据类型总结_oracle 数值类型最大值-程序员宅基地

文章浏览阅读442次。2013-08-17 21:04 by 潇湘隐者, 100246 阅读, 5 评论, 收藏, 编辑 ORACLE基本数据类型(亦叫内置数据类型 built-in datatypes)可以按类型分为:字符串类型、数字类型、日期类型、LOB类型、LONG RAW& RAW类型、ROWID & UROWID类型。在讲叙字符串类型前,先要讲一下编码。字符串类型的数据可依编码方式分成_oracle 数值类型最大值

10种机器学习算法_决策树和mlp-程序员宅基地

文章浏览阅读315次。作为数据科学家的实践者,我们必须了解一些通用机器学习的基础知识算法,这将帮助我们解决所遇到的新领域问题。本文对通用机器学习算法进行了简要的阐述,并列举了它们的相关资源,从而帮助你能够快速掌握其中的奥妙。▌1.主成分分析(PCA)/ SVDPCA是一种无监督的方法,用于对由向量组成的数据集的全局属性进行理解。本文分析了数据点的协方差矩阵,以了解哪些维度(大部分情况)/数据点(少数情况)更为重要,即它..._决策树和mlp

桥接模式的实现-程序员宅基地

文章浏览阅读148次。在这个示例中,我们使用std::shared_ptr来管理Implementor对象的生命周期,确保在不再需要时自动释放资源。通过智能指针的使用,我们避免了手动管理内存的复杂性,提高了代码的可靠性和可维护性。希望这个示例能帮助你理解如何使用智能指针来实现桥接模式。当使用智能指针来实现桥接模式时,我们可以利用std::shared_ptr或std::unique_ptr来管理对象的生命周期,确保资源的正确释放。

制造业敏感文件外发不安全?一招解锁更高效的加密方式!-程序员宅基地

文章浏览阅读440次,点赞11次,收藏8次。云盒子在制造业上有丰富的部署经验,在面向制造类企业的重要文件,可以通过审计、授权、文件加密进行多重保护,使得图纸文件、专利技术、采购订单等敏感数据等到有效保护,做到无处可泄,同时安全可靠,也不会对日常工作效率有影响 ,实现真正有效的企业文件保护的目的,达到既防止机密文件外泄和扩散,又支持内部知识积累和文件共享的目的。云盒子的加密方式是通过将本地文件数据上传到云盘进行统一加密存储,而不是对设备加密,通过【本地加密】+【云加密】双重组合下,不管用什么设备打开文件都受到管控,使管理者管理起来能够更高效。

随便推点

计算几何讲义——计算几何中的欧拉定理-程序员宅基地

文章浏览阅读188次。在处理计算几何的问题中,有时候我们会将其看成图论中的graph图,结合我们在图论中学习过的欧拉定理,我们可以通过图形的节点数(v)和边数(e)得到不是那么好求的面数f。 平面图中的欧拉定理: 定理:设G为任意的连通的平面图,则v-e+f=2,v是G的顶点数,e是G的边数,f是G的面数。证明:其实有点类似几何学中的欧拉公式的证明方法,这里采用归纳证明的方法。对m..._怎么证明平面图欧拉定理

c语言中各种括号的作用,C语言中各种类型指针的特性与用法介绍-程序员宅基地

文章浏览阅读750次。C语言中各种类型指针的特性与用法介绍本文主要介绍了C语言中各种类型指针的特性与用法,有需要的朋友可以参考一下!想了解更多相关信息请持续关注我们应届毕业生考试网!指针为什么要区分类型:在同一种编译器环境下,一个指针变量所占用的内存空间是固定的。比如,在16位编译器环境 下,任何一个指针变量都只占用8个字节,并不会随所指向变量的类型而改变。虽然所有的指针都只占8个字节,但不同类型的变量却占不同的字节数..._c语言带括号指针

缅甸文字库 缅甸语字库 缅甸字库算法_0x103c-程序员宅基地

文章浏览阅读9.5k次。字库交流 QQ:2229691219 缅甸语比较特殊、缅甸语有官方和民间之分,二者不同的是编码机制不同,因此这2种缅甸语的字串翻译、处理引擎、字库都是不同的。我们这里只讨论官方语言。 缅文、泰文等婆罗米系文字大多是元音附标文字,一般辅音字母自带默认元音可以发音,真正拼写词句时元音像标点符号一样附标在辅音上下左右的相应位置。由于每个元音位于辅音的具体位置是有自己的规则的,当只书写..._0x103c

Python+django+vue校园二手闲置物品拍卖系统pycharm毕业设计项目推荐_基于python+django+vue实现的校园二手交易平台-程序员宅基地

文章浏览阅读200次。在校园,随着学生数量的增多,存在许多生活和学习物品,许多学习用品经过一学期学习之后往往被闲置,一些出于一时喜欢而购买的物品使用机会少而被闲置,还有一些物品以低廉的价格卖给资源回收站,造成巨大的资源浪费。校园闲置物品拍卖系统使用python技术,MySQL数据库进行开发,系统后台使用django框架进行开发,具有低耦合、高内聚的特点,其中校园用户通过人脸识别的方法增加系统安全性,在闲置物品推荐中,使用协同过滤算法进行商品推荐。系统的开发,帮助高校有效的对闲置物品进行管理,提高了闲置物品销售的效率。_基于python+django+vue实现的校园二手交易平台

【推荐系统论文精读系列】(十)--Wide&Deep Learning for Recommender Systems_引用《wide & deep learning for recommender systems》-程序员宅基地

文章浏览阅读1.1k次,点赞3次,收藏3次。文章目录Wide & Deep Learning for Recommender Systems一、摘要二、介绍三、推荐系统综述四、Wide&Deep学习4.1 Wide部分4.2 Deep部分4.3 联合训练 Wide&Deep ModelPreferenceWide & Deep Learning for Recommender Systems一、摘要具有非线性特征转化能力的广义线性模型被广泛用于大规模的分类和回归问题,对于那些输入数据是极度稀疏的情况下。通过使用交_引用《wide & deep learning for recommender systems》

c++ sleep函数_Linux 多线程应用中如何编写安全的信号处理函数-程序员宅基地

文章浏览阅读171次。关于代码的可重入性,设计开发人员一般只考虑到线程安全,异步信号处理函数的安全却往往被忽略。本文首先介绍如何编写安全的异步信号处理函数;然后举例说明在多线程应用中如何构建模型让异步信号在指定的线程中以同步的方式处理。Linux 多线程应用中编写安全的信号处理函数在开发多线程应用时,开发人员一般都会考虑线程安全,会使用 pthread_mutex 去保护全局变量。如果应用中使用了信号,而且信号的产生不..._linux c++ sleep 不被中断

推荐文章

热门文章

相关标签