软件开发方法的特点与选择.doc
软件开发方法的特点与选择软件开发软件开发是根据用户要求建造出软件系统或者系统中部分软件的过程。它是一项包括需求捕捉,需求分析,需求设计,实现、测试和维护的系统工程。常见的软件开发方法有1 结构化开发方法结构指系统内各组成要素之间的相互联系、相互作用的框架。结构化开发方法强调系统结构的合理性以及所开发的软件的结构的合理性,主要是面向数据流的,因此也被称为面向功能的软件开发方法或面向数据流的软件开发方法。结构化技术包括结构化分析、结构化设计和结构化程序设计三方面内容。1.1 结构化分析的步骤结构化分析是一种模型的确立活动,就是使用独有的符号,来确立描绘信息(数据和控制)流和内容的模型,划分系统的功能和行为,以及其他为确立模型不可缺少的描述。其基本步骤是:(1)构造数据流模型:根据用户当前需求,在创建实体关系图的基础上,依据数据流图构造数据流模型。(2)构建控制流模型:一些应用系统除了要求用数据流建模外,通过构造控制流图(CFD),构建控制流模型。(3)生成数据字典:对所有数据元素的输入、输出、存储结构,甚至是中间计算结果进行有组织的列表。目前一般采用CASE的“结构化分析和设计工具”来完成。(4)生成可选方案,建立需求规约:确定各种方案的成本和风险等级,据此对各种方案进行分析,然后从中选择一种方案,建立完整的需求规约。1.2 结构化设计步骤结构化设计是采用最佳的可能方法设计系统的各个组成部分以及各成分之间的内部联系的技术,目的在于提出满足系统需求的最佳软件的结构,完成软件层次图或软件结构图。其基本步骤如下:(1)研究、分析和审查数据流图。从软件的需求规格说明中弄清数据流加工的过程。(2)然后根据数据流图决定问题的类型。数据处理问题有两种典型的类型:变换型和事务型。针对两种不同的类型分别进行分析处理。(3)由数据流图推导出系统的初始结构图。也就是把数据流图映射到软件模块结构,设计出模块结构的上层。(4)利用一些试探性原则来改进系统的初始结构图,直到得到符合要求的结构图为止。即在数据流图的基础上逐步分解高层模块,设计中下层模块,并对软件模块结构进行优化,最终得到更为合理的软件结构。(5)描述模块接口。(6)修改和补充数据词典。(7)制定测试计划。结构化设计可以将用数据流图表示的信息转换成程序结构的设计描述。2模块化开发方法模块化程序设计方法就是把一个待开发的软件系统分解成若干可单独命名和编址的较为简单的部分,这些可单独命名和编址的部分称为模块。每个模块分别独立地开发、测试,最后再组装出整个软件系统。这种方法不仅可以将软件系统开发的复杂性在分解过程中降低,便于修改、维护,而且还容易实现同一个系统不同部分的并行开发,从而提高了软件的生产效率。一般,将用一个名字就可调用的一段程序称为“模块”。在考虑模块化时,将模块定义为多大较合适,模块设计规则应如何制定成为关键。特点: (1)模块可分解性:如果一种设计方法提供了将问题分解成子问题的系统化机制,它就能降低整个系统的复杂性,从而实现一种有效的模块化解决方案。 (2)模块可组装性:如果一种设计方法使现存的设计模块能够被组装成新系统,它就能提供一种不用一切从头开始的模块化解决方案。 (3)模块可理解性:如果一个模块可以作为一个独立的单位被理解,那么它就易于构造和修改。 (4)模块连续性:如果对系统需求的微小修改只导致对单个模块而不是对整个系统的修改,则修改引起的副作用就会被最小化。一般来说,对模块采用耦合和内聚两个准则进行度量。如模块内部具有高内聚和模块间低耦合,那这样的模块就具有独立性,模块设计得比较好。3 面向对象开发方法面向对象开发方法是以面向对象程序设计语言作为基础的,其核心思想是利用面向对象的概念和方法为软件需求建立模型,进行系统设计,采用面向对象程序设计语言进行系统实现,对建成的系统进行面向对象的测试和维护。如果一个软件系统是使用这样4个概念设计和实现的,则可以认为这个软件系统是面向对象的。其基本要点可以概括为:(1)数据的抽象,即类与子类的概念及相互关系。任何客观的事物和实体都是对象,复杂对象可以由简单对象组成。(2)数据及对它的操作的一体化,即封装的概念和方法。具有相同数据和操作的对象可归并为一个类,具有封装性,形成一个包装;对象是类的一个实例;一个类可以产生很多对象。(3)属性与操作由父类向子类传递,即继承的概念与方法。类可以派生出子类,继承能避免共同行为的重复。(4)客观事物之间的相互关系用统一的、消息传递的方法来描述。目前广泛使用的面向对象开发方法包括Booch方法、Rumbaugh方法、Coad和Yourdon方法、Jacobson方法、Wirfs-Brock方法和统一建模方法等。4 软件开发方法的评价与选择软件开发方法有很多种,在实际软件开发中,就涉及到选择适宜的开发方法的问题,具体选择时应综合考虑以下方面因素:(1) 开发人员的基本素质及经验阅历。主要看软件开发人员是否对该方法有经验或受过专门训练。(2) 项目进度安排及人员组成情况。要根据开发项目的时间限度、人员配备进行选择。(3) 现有资源状况。考查现有的软硬件环境及可使用的CASE工具等。(4) 进行可行性研究。从计划、组织、管理各个环节综合考虑。选择软件开发方法后,还涉及对所选的开发方法进行评价。一般说来,可以从以下四个方面来进行评价:(1) 技术特征:支持各种技术概念的方法特色。(2) 使用特征:具体开发时的有关特色。(3) 管理特征:增强软件开发活动管理能力方面的特色。(4) 经济特征:使开发部门的生产力和软件质量得到提高,产生经济效益的有关特色。5 结语软件工程技术衍生出很多种软件开发方法,这些方法在各自的适用领域表现出一定的优越性和生命力,面向对象开发方法已逐渐成为软件开发的主流方法,在越来越多的软件项目开发过程中使用。