热门问题
时间线
聊天
视角
结构化分析
来自维基百科,自由的百科全书
Remove ads
结构化分析(Structured Analysis,简称SA)是软件工程中的一种方法,结构化分析和结构化设计可以分析商业的需求,再转换为规格文件,最后再产生电脑软件、硬件配置及相关的手册及程序。

目的
结构化分析在1980年代起开始广为使用。结构化分析包括将系统概念转换为用资料及控制的来表示,也就是转换为资料流程图。资料流程图中的程序以泡泡来表示,因此也称为“泡泡图”。不过完整的资料流程图中可能有许多的“泡泡”,使得很难去追踪资料流动的情形。此时可以先定义外界需要系统回应的事件,每一个事件指定一个泡泡,当系统定义完成后,再将事件的泡泡和回应的程序的泡泡相连接。也可以将程序对应泡泡加以分组,组合成较高阶的程序。资料字典用来描述资料和指令的流动,而用程序规格来描述交易或资料转换的相关资讯[3]。
许多著名的分析方式都和结构化分析(SA)及结构化设计(SD)有关,包括结构图、资料流程图及资料模型图等。许多程式设计方法学也结合了结构化分析及结构化设计,包括结构化系统分析及设计方法(SSADM)及结构化分析及设计技术(SADT)等。
Remove ads
历史
结构化分析是许多结构化方法中的一部分。“结构化分析是系统分析、设计及编程技术的组合,其目的是为了处理1960至1980年代软件开发所遇到的问题,这段期间多半是用COBOL和Fortran语言开发,后来也使用C语言及BASIC,也没有将需求及设计文件化的技术。随着系统越来越大也更加复杂,资讯系统的发展也变得越来越困难。”[4]为了方便管理大而复杂的系统,演进出下列的结构化方法。
自1967年起出现了许多的结构化方法[4]:
- 结构化编程:由艾兹格·迪杰斯特拉在1967年提出-《GOTO陈述有害论》。
- 逐步设计(Stepwise design):由尼克劳斯·维尔特在1971年提出。
- 1972年出现的Nassi-Shneiderman图。
- 1974年提出的Warnier/Orr图-“Logical Construction of Programs”。
- 1974年提出的HIPO-IBM的层次化输入-处理-输出图。
- 结构化设计:由赖瑞·康斯坦丁、爱德华·尤登及韦恩·史帝文斯在1975年提出。
- 杰克逊结构化程式设计:由迈克尔·安东尼·杰克逊在1975年提出。
- 结构化分析:约在1978年由汤姆·狄马克及尤登等人提出。
- 结构化分析及设计技术(SADT):由道格拉斯·T·罗斯发展。
- 尤登结构化方法:由爱德华·尤登提出。
- 结构化分析及系统规格(Structured Analysis and System Specification):由汤姆·狄马克在1979年提出。
- 结构化系统分析及设计方法 (SSADM):最早是由英国商务办公室在1983年提出。
- 以结构化分析及设计技术为基础的IDEF0,由道格拉斯·T·罗斯在1985年提出[5]。
- Hatley-Pirbhai模型:在 Derek J. Hatley及Imtiaz A. Pirbhai于1988年所著的《Strategies for Real-Time System Specification》中定义。
- 资讯工程:约在1990年代由克莱夫·芬克尔斯坦提出,后来因詹姆斯·马丁的推广而广为人知。
依照Hay在1999年提出的定义:“资讯工程是1970年代提出许多结构化技术的延伸。先由结构化编程进展到结构化设计,然后进展到结构化系统分析。这些技术使用的图也所不同:结构化设计中使用结构图,而结构化系统分析使用资料流程图。二者都可以帮助程序开发者及用户的沟通,并且提升程序分析者及设计者的纪律。1980年起开始有工具可以自动绘制这类的图面,并追踪资料字典中的内容。”[6]在电脑辅助设计及电脑辅助制造(CAD/CAM)名词广为使用之后,上述工具的使用也称为电脑辅助软件工程(CASE)。
Remove ads
结构化分析主题

结构化分析一般会建立一个使用单一抽象化机制(single abstraction mechanism)的层次结构系统。结构化分析方法可以使用IDEF(如图),IDEF是一个程序驱动的分析方法,是由目的及观点开始进行。此方法一开始会先确认整体机能,再反复地将机能分割为更小的机能,保留程序优化需要的输入、输出、控制及机制。IDEF也被视为是一种功能分解的分析方法,着重在函数的内聚力及函数之间的耦合力[7]。
功能分解的结构化方法单纯描述程序,而不去划定系统的行为,也不决定需要机能的系统架构。此方法只确认和活动有关的输入及输出。结构化分析受欢迎的一个原因是其本质适合描述一个高阶的程序及概念,即使企业层次的程序也相当适合。不过对于商业常用的面向对象过程中,物件需要有哪些机能,IDEF提供的资讯很有限。统一建模语言(UML)和IDEF相反,统一建模语言是接口驱动,并且有多重抽象化机制,适用于描述面向服务的架构(SOA)。
Remove ads
结构化分析以资料在不同模块中流动的观点来看待一个系统,系统的功能可以用转换资料流的程序来表示。结构化分析善用了功能拆解(或由上到下设计)的资讯隐藏特性,因此可以关注在重要的细节,而不会被无关的细节干扰。当细节的层级提高时,资讯的广度也随之减少。结构化分析的结果是一组相关的图,程序描述以及资料定义,这些资料描述一个程序为符合机能性需求所需要的资料以及需进行的转换[8]。

资料流程图是一个有向图,弧线表示资料,节点(用圆圈或泡泡表示)表示转换资料的程序。程序还可以再细分为更细的资料流程图,描述程序中的子程序,一直到清楚说明及了解程序机能为止。机能元(functional primitive)是指一些不需再细分的程序,一般会用程序规格(或微规格)来说明。程序规格可以包括伪代码、流程图或结构化英文。资料流程图将系统的架构表示为一个由许多互连的程序形成的网络,而各程序是由机能元所组合而成。资料字典是一组资料流、资料元素、文件及数据库的定义。资料流程图或其他资料字典可以参考资料字典中的内容[8]。
Remove ads

系统关系图(System Context Diagram)是表示系统和外界环境之间的作用[11],系统关系图可以表示一个系统和外界相关系统的输入及输出。
Kossiakoff将系统关系图定义为“系统关系图将系统放在整个图的中心,不描述其内部结构,周围则是和其有关的系统、活动及环境,环境图的目的是专注在哪些会影响系统需求及限制的外部因素及事件。”[11]系统关系图和资料流程图有关,有助于了解系统和其他相关系统或事件之间的关系。

资料字典或是数据库字典是定义数据库基本组织的文件[12]。资料字典包括数据库中所有的文件、每一个文件的字段个数、字段名称及类型。为了保护资料字典的内容不被破坏,大部分的数据库管理系统不允许用户更改资料字典。资料字典没有数据库中的资料内容,只有一些存取数据库需要的资讯。数据库管理系统一定要配合资料字典才能存取数据库的内容[12]。

资料流程图(DFD)是用图像方式表示资讯系统中资料的流动方式。资料流程图和系统流程图不同,主要是表示资料在不同程序之间的流动,而不是程序的控制流程。资料流程图是由赖瑞·康斯坦丁所提出,是以Martin及Estrin的“资料流图”(data flow graph)为基础[14]。
一般在绘制资料流程图前,会先绘制环境图,描述系统和外界环境的交互作用。资料流程图可以将系统分割为几个较小的部分,并且强调各部分之间的资料流动。资料流程图是结构化系统分析及设计方法(SSADM)的三个重要图表中的一个。

结构图(SC)是一个将系统拆解为最小可管理程序单位的图[15]。在结构化编程中,结构图可以将程序模块整理为树状结构,每一个模块以一个其中有模块名称的方框表示,树状结构可以清楚表示各模块之间的关系[16]。
结构化分析中常用结构图表示程序的顶层架构。结构图有助于程式设计者用个个击破的方式处理软件问题,也就是将一直将问题拆解为更小的问题,直到最后问题小到可以被人类理解为止。此程序称为由上到下设计或是功能分解。结构图的作用类似建筑房屋中使用的蓝图。在设计阶段,结构图是客户和不同软件工程师沟通的方式。在代码实现的阶段,由结构图可以得知系统的完整架构[17]。
结构化设计(SD)是有关软件模块的开发,及分析模块之间的“模块层次”(module hierarchy)[18],
在结构化设计中,有以下二个主要的概念:
当耦合力调整到最佳情形时,会简化模块之间的接口,也会简化程序的复杂度[8]。
Page-Jones在1980年提出的研究中有三个主题:结构图、模块规格及资料字典[18]。“结构图的目的是表示模块层次,模块规格可以用伪代码或程式设计语言来组成,资料字典类似结构化分析中的资料字典,在软件开发生命周期中,在已经进行了分析及设计后,就可以自动产生资料类型的宣告[19],以及程序或副程序的模版。[8]”
爱德华·尤登及赖瑞·康斯坦丁也有提出结构化分析的概念。
结构化查询语言(SQL)是一种查询数据库的标准语言。结构化查询语言一开始是用在一个商用数据库系统中,后来成为在迷你电脑及大型电脑运作的数据库管理系统中,最受欢迎的数据库查询语言。结构化查询语言也可在一般个人电脑中的数据库管理系统中使用,并且可配合分布式数据库使用,因此允许许多用户在网络上同时存取同一个数据库的内容[12]。
相关条目
- 事件分割
- HIPO
- 杰克逊结构化程式设计
- 软件系统方法论
- 尤登结构化方法
- 基于流编程
参考资料
延伸阅读
外部链接
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads