• 瀑布模型的软件开发有三个特点?软件生命周期的顺序性


    第一个是软件生命周期的顺序性,顺序性是指只有前一阶段的工作完成之后,后一阶段的工作才能开始,前一阶段的输出文档就是后一阶段的输入文档。只有前一阶段有正确的输出,后一阶段才可能有正确的结果。因而,瀑布模型的特点是由文档驱动的。如果在生命周期的某一阶段出现了错误,往往要追溯到在它之前的一些阶段。

     

    第二个是推迟软件的编码,瀑布模型在编码之前安排了需求分析,概要设计和详细设计等阶段,从而把逻辑设计和编码清楚地划分开,尽可能推迟编码阶段。

    那什么是概要设计呢?在软件设计中,大家经常问到的一个问题是:概要设计应该怎样一个概要法,详细设计应该怎样一个详细法?

    回答:概要(结构)设计阶段:把软件按照一定的原则分解为模块层次,赋予每个模块一定的任务,并确定模块间调用关系和接口。

    概要设计有多种方法。在早期有模块化方法、功能分解方法;在60年代后期提出了面向数据流和面向数据结构的设计方法;近年来又提出面向对象的设计方法等。

    下面,我们看下概要设计的格式如下:

    1引言

    1.1编写目的

    1.2背景

    1.3定义

    1.4参考资料

    2总体设计

    2.1需求规定

    2.2运行环境

    2.3基本设计概念和处理流程

    2.4系统架构

    2.5功能需求与程序的关系

    2.6人工处理过程

    2.7尚未解决的问题

    3接口设计

    3.1用户接口

    3.2外部接口

    3.3内部接口

    4运行设计

    4.1运行模块组合

    4.2运行控制

    4.3运行时间

    5系统数据结构设计

    5.1逻辑结构设计要点

    5.2物理结构设计要点

    5.3数据结构与程序的关系

    6系统出错处理设计

    6.1出错信息

    6.2补救措施

    6.3系统维护设计

    一般公司的研发流程是瀑布型的,这个模型中的分析、设计阶段是基于经典的结构化方法。 结构化设计方法的基本思路是:按照问题域,将软件逐级细化,分解为不必再分解的的模块,每个模块完成一定的功能,为一个或多个父模块服务(即接受调用),也接受一个或多个子模块的服务(即调用子模块)。模块的概念,和编程语言中的子程序或函数是对应的。

    这样一来,设计可以明显地划分成两个阶段:

        概要(结构)设计阶段:把软件按照一定的原则分解为模块层次,赋予每个模块一定的任务,并确定模块间调用关系和接口。


        详细设计阶段:依据概要设计阶段的分解,设计每个模块内的算法、流程等。

    概要设计的主要任务是把需求分析得到的系统扩展用例图转换为软件结构和数据结构。设计软件结构的具体任务是:将一个复杂系统按功能进行模块划分、建立模块的层次结构及调用关系、确定模块间的接口及人机界面等。数据结构设计包括数据特征的描述、确定数据的结构特性、以及数据库的设计。显然,概要设计建立的是目标系统的逻辑模型,与计算机无关。

    一、概要设计阶段

    在这个阶段,设计者会大致考虑并照顾模块的内部实现,但不过多纠缠于此。主要集中于划分模块、分配任务、定义调用关系。模块间的接口与传参在这个阶段要定得 十分细致明确,应编写严谨的数据字典,避免后续设计产生不解或误解。概要设计一般不是一次就能做到位,而是反复地进行结构调整。典型的调整是合并功能重复的模块,或者进一步分解出可以复用的模块。在概要设计阶段,应最大限度地提取可以重用的模块,建立合理的结构体系,节省后续环节的工作量。

    概要设计文档最重要的部分是分层数据流图、结构图、数据字典以及相应的文字说明等。以概要设计文档为依据,各个模块的详细设计就可以并行展开了。
    二、详细设计阶段

        在这个阶段,各个模块可以分给不同的人去并行设计。在详细设计阶段,设计者的工作对象是一个模块,根据概要设计赋予的局部任务和对外接口,设计并表达出模块的算法、流程、状态转换等内容。这里要注意,如果发现有结构调整(如分解出子模块等)的必要,必须返回到概要设计阶段,将调整反应到概要设计文档中,而不能就地解决,不打招呼。
        详细设计文档最重要的部分是模块的流程图、状态图、局部变量及相应的文字说明等。一个模块一篇详细设计文档。
        概要设计文档相当于机械设计中的装配图,而详细设计文档相当于机械设计中的零件图。文档的编排、装订方式也可以参考机械图纸的方法。
        概要设计中较顶层的部分便是所谓的方案。方案文档的作用是在宏观的角度上保持设计的合理性。 有的项目采用面向对象的分析、设计方法。可能在概要设计、详细设计的分工上疑问更多。其实,面向对象的分析、设计方法并没有强调结构化方法那样的阶段性,因此一般不引入概要、详细设计的概念。如果按照公司的文档体系,非要有这种分工的话,可以将包的划分、类及对象间的关系、类的对外属性、方法及协作设计看做 概要设计;类属性、方法的内部实现看做详细设计。

        需求分析--产生软件功能规格说明书,需要确定用户对软件的需求,要作到明确、无歧义。不涉及具体实现方法。用户能看得明白,开发人员也可据此进行下面的工作(概要设计)。
        概要设计--产生软件概要设计说明书,说明系统模块划分、选择的技术路线等,整体说明软件的实现思路。并且需要指出关键技术难点等。   
        详细设计--产生软件详细设计说明书,对概要设计的进一步细化,一般由各部分的担当人员依据概要设计分别完成,然后在集成,是具体的实现细节。理论上要求可以照此编码。

    三、概要设计和详细设计的区别与联系

        概要设计就是设计软件的结构,包括组成模块,模块的层次结构,模块的调用关系,每个模块的功能等等。同时,还要设计该项目的应用系统的总体数据结构和数据库结构,即应用系统要存储什么数据,这些数据是什么样的结构,它们之间有什么关系。 详细设计阶段就是为每个模块完成的功能进行具体的描述,要把功能描述转变为精确的、结构化的过程描述。

        概要设计阶段通常得到软件结构图,详细设计阶段常用的描述方式有:流程图、N-S图、PAD图、伪代码等。

        软件设计采用自顶向下、逐次功能展开的设计方法,首先完成总体设计,然后完成各有机组成部分的设计。根据工作性质和内容的不同,软件设计分为概要设计和详细设计。概要设计实现软件的总体设计、模块划分、用户界面设计、数据库设计等等;详细设计则根据概要设计所做的模块划分,实现各模块的算法设计,实现用户界面设计、数据结构设计的细化,等等。
        概要设计是详细设计的基础,必须在详细设计之前完成,概要设计经复查确认后才可以开始详细设计。概要设计,必须完成概要设计文档,包括系统的总体设计文档、以及各个模块的概要设计文档。每个模块的设计文档都应该独立成册。
        详细设计必须遵循概要设计来进行。详细设计方案的更改,不得影响到概要设计方案;如果需要更改概要设计,必须经过项目经理的同意。详细设计,应该完成详细设计文档,主要是模块的详细设计方案说明。和概要设计一样,每个模块的详细设计文档都应该独立成册。

        概要设计里面的数据库设计应该重点在描述数据关系上,说明数据的来龙去脉,在这里应该结合我们的一下结果数据,说明这些结果数据的源点,我们这样设计的目的和原因。详细设计里的数据库设计就应该是一份完善的数据结构文档,就是一个包括类型、命名、精度、字段说明、表说明等内容的数据字典。
        概要设计里的功能应该是重点在功能描述,对需求的解释和整合,整体划分功能模块,并对各功能模块进行详细的图文描述,应该让读者大致了解系统作完后大体的结构和操作模式。详细设计则是重点在描述系统的实现方式,各模块详细说明实现功能所需的类及具体的方法函数,包括涉及到的sql语句等。
     第三个瀑布模型开发特点是保证质量 质量保证观点
        瀑布模型每阶段坚持两个重要做法:
        一是每阶段都必须完成完整、准确的文档。软件开发时人员间通信、运行时期维护的重要依据。
        二是每阶段结束前对文档评审。

      传统瀑布模型过于理想化,但人在工作过程中
    不可能不犯错误,所以实际瀑布模型带反馈环。

    优点:
        提高软件质量,降低维护成本,缓解软件危机。
    缺点:
        模型缺乏灵活性,无法解决需求不明确问题。用户不经过实践提出完整准确需求不切实际。

     

  • 相关阅读:
    python --阿里云(智能媒体管理/视频点播)
    Hadoop环境搭建-单机、伪分布式、完全分布式
    Java配置26-前后端配置大文件上传
    JS 算法专辑【4】链表
    红宝石阅读笔记
    【面试】线上压测,常见的几个问题
    AWK用法全解与sed去掉sql最后一个字段哪一行的逗号
    工作十多年后反思自己为什么没有成为牛逼程序员
    如何保证优秀的医疗器械设计?
    设计模式--策略模式
  • 原文地址:https://blog.csdn.net/qq19931130/article/details/125636191