一、软件工程概述
1.软件特点
软件:计算机程序、方法、规则、相关的文档资料,以及计算机程序运行时所需要的数据。
软件是计算机系统中的逻辑成分,具有无形性。其主要内容包括:程序、配置文件、系统
文档、用户文档等。
2.软件分类
(1)按功能划分:系统软件、支撑软件、应用软件。
(2)按工作方式划分:实时处理软件、分时处理软件、交互式软件、批处理软件。
(3)按规模划分:微型软件、小型软件、中型软件、大型软件。
(4计算机软件系统)按服务对象划分:通用软件、定制软件。
3.软件发展阶段
(1)程序设计时代(20世纪50年代)。
(2)程序系统时代(20世纪60年代)。
(3)软件工程时代(20世纪70年代起)。
4.软件危机
(1)危机现象:软件开发成本与进度估计不准确,软件产品与用户要求不一致,软件产品质量可靠性差,软件文档不完整不一致,软件产品可维护性差,软件生产率低。
(2)危机原因:软件的不可见性,系统规模庞大,生产工程化程度低,对用户需求关心不
够,对维护不够重视,开发工具自动化程度低。
5.软件工程
软件工程:运用现代科学技术知识来设计并构造计算机程序及为开发、运行和维护这些程序所必须的相关文件资料。
软件工程是一门关于软件开发与维护的工程学科,它涉及软件生产的各个方面,能够为经济、高效地开发高质量的软件产品提供最有效的支持。
(1)工程方法:结构化方法、JSD方法、面向对象方法。
(2)软件工具:具有自动化特征的软件开发集成支撑环境。
(3)工程过程:在软件工具支持下的一系列工程活动,基本活动是软件定义、软件开发、
软件验证、软件维护。
(4)工程管理:项目规划,项目资源调配,软件产品控制。
(5)工程原则:分阶段生命周期计划,阶段评审制度,严格的产品控制,采用先进的技术,
成果能清楚地审查,开发队伍精练,不断改进工程实践。
(6)工程目标:开发成本较低,软件功能能满足用户需求,软件性能较好,软件可靠性高,
软件易于使用、维护与移植,能按时完成开发任务并及时交付使用。
(7)工程文化:包括工程价值、工程思想和工程行为三个方面的内容。
二、软件工程过程模型
1.软件生命周期
如同任何事物都有一个发生、发展、成熟直至衰亡的全过程一样,软件系统或软件产品也有一个定义、开发、运行维护直至被淘汰这样的全过程,我们把软件将要经历的这个全过程称为软件的生命周期。它包含:软件定义、软件开发、软件运行维护三个时期,并可以细分为可行性研究、项目计划、需求分析、概要设计、详细设计、编码实现与单元测试、系统集成测试、系统确认验证、系统运行与维护等几个阶段。
软件定义期
软件定义是软件项目的早期阶段,主要由软件系统分析人员和用户合作,针对有待开发的软件系统进行分析、规划和规格描述,确定软件是什么,为今后的软件开发做准备。这个时期往往需要分阶段地进行以下几项工作。
1.软件任务立项
软件项目往往开始于任务立项,并需要以“软件任务立项报告”的形式针对项目的名称、性质、目标、意义和规模等作出回答,以此获得对准备着手开发的软件系统的最高层描述。
2.项目可行性分析
在软件任务立项报告被批准以后,接着需要进行项目可行性分析。可行性分析是针对准备进行的软件项目进行的可行性风险评估。因此,需要对准备开发的软件系统提出高层模型,并根据高层模型的特征,从技术可行性、经济可行性和操作可行性这三个方面,以“可行性研究报告”的形式,对项目作出是否值得往下进行的回答,由此决定项
目是否继续进行下去。
3.制定项目计划
在确定项目可以进行以后,接着需要针对项目的开展,从人员、组织、进度、资金、设备等多个方面进行合理的规划,并以“项目开发计划书”的形式提交书面报告。
4.软件需求分析
软件需求分析是软件规格描述的具体化与细节化,是软件定义时期需要达到的目标。
需求分析要求以用户需求为基本依据,从功能、性能、数据、操作等多个方面,对软件系统给出完整、准确、具体的描述,用于确定软件规格。其结果将以“软件需求规格说明书”的形式提交。
在软件项目进行过程中,需求分析是从软件定义到软件开发的最关键步骤,其结论不仅是今后软件开发的基本依据,同时也是今后用户对软件产品进行验收的基本依据。
软件开发期
在对软件规格完成定义以后,接着可以按照“软件需求规格说明书”的要求对软件实施开发,并由此制作出软件产品。这个时期需要分阶段地完成以下几项工作。
1.软件概要设计
概要设计是针对软件系统的结构设计,用于从总体上对软件的构造、接口、全局数据结构
和数据环境等给出设计说明,并以“概要设计说明书”的形式提交书面报告,其结果将成为详细设计与系统集成的基本依据。
模块是概要设计时构造软件的基本元素,因此,概要设计中软件也就主要体现在模块的构成与模块接口这两个方面上。结构化设计中的函数、过程,面向对象设计中的类、对象,它们都是模块。概要设计时并不需要说明模块的内部细节,但是需要进行全部的有关它们构造的定义,包括功能特征、数据特征和接口等。
在进行概要设计时,模块的独立性是一个有关质量的重要技术性指标,可以使用模块的内聚、耦合这两个定性参数对模块独立性进行度量。
2.软件详细设计
设计工作的第二步是详细设计,它以概要设计为依据,用于确定软件结构中每个模块的内部细节,为编写程序提供最直接的依据。
详细设计需要从实现每个模块功能的程序算法和模块内部的局部数据结构等细节内容上给出设计说明,并以“详细设计说明书”的形式提交书面报告。
3.编码和单元测试
编码是对软件的实现,一般由程序员完成,并以获得源程序基本模块为目标。
编码必须按照“详细设计说明书”的要求逐个模块地实现。在基于软件工程的软件开发过程中,编码往往只是一项语言转译工作,即把详细设计中的算法描述语言转译成某种适当的高级程序设计语言或汇编语言。
为了方便程序调试,针对基本模块的单元测试也往往和编码结合在一起进行。单元测试也以“详细设计说明书”为依据,用于检验每个基本模块在功能、算法与数据结构上是否符合设计要求。
4.系统集成测试
所谓系统集成也就是根据概要设计中的软件结构,把经过测试的模块,按照某种选定的集成策略,例如渐增集成策略,将系统组装起来。
在组装过程中,需要对整个系统进行集成测试,以确保系统在技术上符合设计要求,在应用上满足需求规格要求。
5.系统确认验证
在完成对系统的集成之后,接着还要对系统进行确认验证。
系统确认验证需要以用户为主体,以需求规格说明书中对软件的定义为依据,由此对软件的各项规格进行逐项地确认,以确保已经完成的软件系统与需求规格的一致性。为了方便用户在系统确认期间能够积极参入,也为了系统在以后的运行过程中能够被用户正确使用,这个时期往往还需要以一定的方式对用户进行必要的培训。
在完成对软件的验收之后,软件系统可以交付用户使用,并需要以“项目开发总结报告”的书面形式对项目进行总结。
软件运行与维护期
软件系统的运行是一个比较长久的过程,跟软件开发机构有关的主要任务是对系统进行经常性的有效维护。
软件的维护过程,也就是修正软件错误,完善软件功能,由此使软件不断进化升级的过程,
以使系统更加持久地满足用户的需要。因此,对软件的维护也可以看成为对软件的再一次开发。在这个时期,对软件的维护主要涉及三个方面的任务,即改正性维护、适应性维护和完善性维护。
2.瀑布模型
瀑布模型诞生于20世纪70年代,是最经典的并获得最广泛应用的软件过程模型。瀑布模型中的“瀑布”是对这个模型的形象表达,即山顶倾泻下来的水,自顶向下、逐层细化。
(1)特点:线性化模型、阶段具有里程碑特征、基于文档的驱动、阶段评审机制。
(2)作用:为软件项目按规程管理提供了便利,为其他过程模型的推出提供了一个良好的
拓展平台。
(3)局限性:主要适合于需求明确且无大的需求变更的软件开发,但不适合分析初期需求
模糊的项目。
3.原型模型
(1)快速原型方法:是原型模型在软件分析、设计阶段的应用,用来解决用户对软件系统在需求上的模糊认识,或用来试探某种设计是否能够获得预期结果。
(2)原型进化模型:针对有待开发的软件系统,先开发一个原型给用户使用,然后根据用
户的使用意见,对原型不断修改,使它逐步接近,并最终到达开发目标。
4.增量模型
增量模型结合了瀑布模型与原型进化模型的优点。在整体上按照瀑布模型的流程实施开发,以方便对项目的管理。但在软件的实际创建中,则将软件系统按功能分解为许多增量构件逐个地创建与交付,直到全部构件创建完毕,并都被集成到系统之中交付使用。
比较瀑布模型、原型进化模型,增量模型具有非常显著的优越性。但增量模型对软件设计有更高的技术要求。
5.螺旋模型
螺旋模型是一种引入了风险分析与规避机制的过程模型,是瀑布模型、快速原型方法和风险分析方法的有机结合。其基本方法是,在各个阶段创建原型进行项目试验,以降低各个阶段可能遇到的项目风险。
6.喷泉模型
喷泉模型是专门针对面向对象软件开发方法而提出的。“喷泉”一词用于形象地表达面向对象软件开发过程中的迭代和无缝过渡。
7.组件复用模型
组件复用方法是最近几年发展起来的先进的软件复用技术,在基于组件复用的软件开发中,软件由组件装配而成,这就如同用标准零件装配汽车一样。因此,组件复用模型能够有效地提高软件生产率。
三、项目分析与规划
1.计算机系统分析
(1)计算机系统
计算机系统是一个非常复杂并具有智能特性的开发系统,包括:硬件系统、软件系统、网络通信系统、人工操作系统等诸多子系统。
(2)系统分析
系统分析是对软件项目的高层分析,需要获取的是有关系统的框架描述,并需要使系统从它所处的环境中分离出来,为划分系统边界与确定系统构架提供依据。
(3)系统分析模型
分析模型是指采用作图方式对系统进行直观的描述。系统前期分析过程中经常使用的图形模型有系统框架图和系统流程图。其中,系统框架图用于说明系统的基本构造框架,而系统流程图则用于表现系统的基本加工流程。
2.项目可行性分析
(1)意义
•以少量的费用对项目能否实施尽早作出决断。
•根据项目条件限制,对系统的体系构造、工作模式等作出高层抉择。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论