软件工程的几个步骤

2020-12-05 11:44| 发布者: |

  Boehm运用现代科学技术知识来设计并构造计算机程序及为开发、运行和维护这些程序所必需的相关文件资料。

  IEEE软件工程是开发、运行、维护和修复软件的系统方法。

  Fritz Bauer建立并使用完善的工程化原则以较经济的手段获得能在实际机器上有效运行的可靠软件的一系列方法。

  软件开发技术包含软件工程方法学、软件工具和软件开发环境软件工程管理学包含软件工程经济学和软件管理学。

  著名软件工程专家B.Boehm综合有关专家和学者的意见并总结了多年来开发软件的经验于1983年在一篇论文中提出了软件工程的七条基本原理。

  1用分阶段的生存周期计划进行严格的管理。

  B.Boehm指出遵循前六条基本原理能够实现软件的工程化生产按照第七条原理不仅要积极主动地采纳新的软件技术而且要注意不断总结经验。

  (1)软件工程目标生产具有正确性、可用性以及开销合宜的产品。正确性指软件产品达到预期功能的程度。可用性指软件基本结构、实现及文档为用户可用的 程度。开销合宜是指软件开发、运行的整个开销满足用户要求的程度。这些目标的实现不论在理论上还是在实践中均存在很多待解决的问题它们形成了对过程、过 程模型及工程方法选取的约束。

  (2)软件工程过程生产一个最终能满足需求且达到工程目标的软件产品所需要的步骤。软件工程过程主要包括开发 过程、运作过程、维护过程。它们覆盖了需求、设计、实现、确认以及维护等活动。需求活动包括问题分析和需求分析。问题分析获取需求定义又称软件需求规 约。需求分析生成功能规约。设计活动一般包括概要设计和详细设计。概要设计建立整个软件系统结构包括子系统、模块以及相关层次的说明、每一模块的接口定 义。详细设计产生程序员可用的模块说明包括每一模块中数据结构说明及加工描述。实现活动把设计结果转换为可执行的程序代码。确认活动贯穿于整个开发过 程实现完成后的确认保证最终产品满足用户的要求。维护活动包括使用过程中的扩充、修改与完善。伴随以上过程还有管理过程、支持过程、培训过程等。

  (3)软件工程的原则是指围绕工程设计、工程支持以及工程管理在软件开发过程中必须遵循的原则。

  围绕工程设计、工程支持以及工程管理已提出了以下四条基本原则

  该原则与系统设计有关。在系统设计中软件需求、硬件需求以及其它因素间是相互制约和影响的经常需要权衡。因此必需认识需求定义的易变性采用适当的开发模型保证软件产品满足用户的要求。

  在软件设计中通常需要考虑软件的模块化、抽象与信息隐蔽、局部化、一致性以及适应性等特征。合适的设计方法有助于这些特征的实现以达到软件工程的目标。

  工欲善其事必先利其器。在软件工程中软件工具与环境对软件过程的支持颇为重要。软件工程项目的质量与开销直接取决于对软件工程所提供的支撑质量和效用。

  软件工程的管理直接影响可用资源的有效利用生产满足目标的软件产品以及提高软件组织的生产能力等问题。因此仅当软件过程予以有效管理时才能实现有效的软件工程。

  采用工程的概念、原理、 技术和方法来开发与维护软件把经过时间考验而证明正确的管理技术和当前能够 得到的最好的技术方法结合起来这就是软件工程。

  软件工程强调使用生存周期方法学和各种结构分析及结构设计技术。它们是在七十年代为了对付应用软件日益增长的复杂程度、漫长的开发周期以及用户对软件产 品经常不满意的状况而发展起来的。人类解决复杂问题时普遍采用的一个策略就是“各个击破”也就是对问题进行分解然后再分别解决各个子问题的策略。软件工 程采用的生存周期方法学就是从时间角度对软件开发和维护的复杂问题进行分解把软件生存的漫长周期依次划分为若干个阶段每个阶段有相对独立的任务然后 逐步完成每个阶段的任务。采用软件工程方法论开发软件的时候从对任务的抽象逻辑分析开始一个阶段一个阶段地进行开发。前一个阶段任务的完成是开始进行 后一个阶段工作的前提和基础而后一阶段任务的完成通常是使前一阶段提出的解法更进一步具体化加进了更多的物理细节。每一个阶段的开始和结束都有严格标 准对于任何两个相邻的阶段而言前一阶段的结束标准就是后一阶段的开始标准。在每一个阶段结束之前都必须进行正式严格的技术审查和管理复审从技术和管 理两方面对这个阶段的开发成果进行检查通过之后这个阶段才算结束如果检查通不过则必须进行必要的返工并且返工后还要再经过审查。审查的一条主要标 准就是每个阶段都应该交出“最新式的”即和所开发的软件完全一致的高质量的文档资料从而保证在软件开发工程结束时有一个完整准确的软件配置交付使 用。文档是通信的工具它们清楚准确地说明了到这个时候为止关于该项工程已经知道了什么同时确立了下一步工作的基础。此外文档也起备忘录的作用如 果文档不完整那么一定是某些工作忘记做了在进入生存周期的下一阶段之前必须补足这些遗漏的细节。在完成生存周期每个阶段的任务时应该采用适合该阶 段任务特点的系统化的技术方法──结构分析或结构设计技术。

  把软件生存周期划分成若干个阶段每个阶段的任务相对独立而且比较简 单便于不同人员分工协作从而降低了整个软件开发工程的困难程度在软件生存周期的每个阶段都采用科学的管理技术和良好的技术方法而且在每个阶段结束 之前都从技术和管理两个角度进行严格的审查合格之后才开始下一阶段的工作这就使软件开发工程的全过程以一种有条不紊的方式进行保证了软件的质量特 别是提高了软件的可维护性。总之采用软件工程方法论可以大大提高软件开发的成功率软件开发的生产率也能明显提高。

  目前划分软件生 存周期阶段的方法有许多种软件规模、种类、开发方式、开发环境以及开发时使用的方法论都影响软件生存周期阶段的划分。在划分软件生存周期的阶段时应该遵 循的一条基本原则就是使各阶段的任务彼此间尽可能相对独立同一阶段各项任务的性质尽可能相同从而降低每个阶段任务的复杂程度简化不同阶段之间的联 系有利于软件开发工程的组织管理。一般说来软件生存周期由软件定义、软件开发和软件维护三个时期组成每个时期又进一步划分成若干个阶段。下面的论述 主要针对应用软件对系统软件也基本适用。

  软件定义时期的任务是确定软件开发工程必须完成的总目标确定工程的可行性导出实现工程 目标应该采用的策略及系统必须完成的功能估计完成该项工程需要的资源和成本并且制定工程进度表。这个时期的工作通常又称为系统分析由系统分析员负责 完成。软件定义时期通常进一步划分成三个阶段即问题定义、可行性研究和需求分析。

  开发时期具体设计和实现在前一个时期定义的软件它通常由下述四个阶段组成总体设计详细设计编码和单元测试综合测试。

  维护时期的主要任务是使软件持久地满足用户的需要。具体地说当软件在使用过程中发现错误时应该加以改正当环境改变时应该修改软件以适应新的环境当 用户有新要求时应该及时改进软件满足用户的新需要。通常对维护时期不再进一步划分阶段但是每一次维护活动本质上都是一次压缩和简化了的定义和开发过程。

  问题定义阶段必须回答的关键问题“要解决的问题是什么”如果不知道问题是什么就试图解决这个问题显然是盲目的只会白白浪费时间和金钱最终得出 的结果很可能是毫无意义的。尽管确切地定义问题的必要性是十分明显的但是在实践中它却可能是最容易被忽视的一个步骤。

  通过问题定义 阶段的工作系统分析员应该提出关于问题性质、工程目标和规模的书面报告。通过对系统的实际用户和使用部门负责人的访问调查分析员扼要地写出他对问题的 理解并在用户和使用部门负责人的会议上认真讨论这份书面报告澄清含糊不精的地方改正理解不正确的地方最后得出一份双方都满意的文档。

  问题定义阶段是软件生存周期中最简短的阶段一般只需要一天甚至更少的时间。

  这个阶段要回答的关键问题“对于上一个阶段所确定的问题有行得通的解决办法吗”为了回答这个问题系统分析员需要进行一次大大压缩和简化了的系统分析和设计的过程也就是在较抽象的高层次上进行的分析和设计的过程。

  可行性研究应该比较简短这个阶段的任务不是具体解决问题而是研究问题的范围探索这个问题是否值得去解是否有可行的解决办法。

  在问题定义阶段提出的对工程目标和规模的报告通常比较含糊。可行性研究阶段应该导出系统的高层逻辑模型通常用数据流图表示并且在此基础上更准确、 更具体地确定工程规模和目标。然后分析员更准确地估计系统的成本和效益对建议的系统进行仔细的成本效益分析是这个阶段的主要任务之一。

  可行性研究的结果是使用部门负责人做出是否继续进行这项工程的决定的重要依据一般说来只有投资可能取得较大效益的那些工程项目才值得继续进行下去。可行性研究以后的那些阶段将需要投入要多的人力物力。及时中止不值得投资的工程项目可以避免更大的浪费。

  这个阶段的任务仍然不是具体地解决问题而是准确地确定“为了解决这个问题目标系统必须做什么”主要是确定目标系统必须具备哪些功能。

  用户了解他们所面对的问题知道必须做什么但是通常不能完整准确地表达出他们的要求更不知道怎样利用计算机解决他们的问题软件开发人员知道怎样使 用软件实现人们的要求但是对特定用户的具体要求并不完全清楚。因此系统分析员在需求分析阶段必须和用户密切配合充分交流信息以得出经过用户确认的系 统逻辑模型。通常用数据流图、数据字典和简要的算法描述表示系统的逻辑模型。

  在需求分析阶段确定的系统逻辑模型是以后设计和实现目标 系统的基础因此必须准确完整地体现用户的要求。系统分析员通常都是计算机软件专家技术专家一般都喜欢很快着手进行具体设计然而一旦分析员开始谈论 程序设计的细节就会脱离用户使他们不能继续提出他们的要求和建议。较件工程使用的结构分析设计的方法为每个阶段都规定了特定的结束标准需求分析阶段 必须提供完整准确的系统逻辑模型经过用户确认之后才能进入下一个阶段这就可以有效地防止和克服急于着手进行具体设计的倾向。

  这个阶段必须回答的关键问题是“概括地说应该如何解决这个问题”

  首先应该考虑几种可能的解决方案。列如目标系统的一些主要功能是用计算机自动完成还是用人工完成如果使用计算机那么是使用批处理方式还是人机交互方式信息存储使用传统的文件系统还是数据库……。通常至少应该考虑下述几类可能的方案

  低成本的解决方案。系统只能完成最必要的工作不能多做一点额处的工作。

  中等成本的解决方案。这样的系统不仅能够很好地完成预定的任务使用起来很方便而且可能还具有用户没有具体指定的某些功能和特点。虽然用户没有提出这些具体要求但是系统分析员根据自己的知识和经验断定这些附加的能力在实践中将证明是很有价值的。

  高成本的“十全十美”的系统。这样的系统具有用户可能希望有的所有功能和特点。

  系统分析员应该使用系统流程图或其他工具描述每种可能的系统估计每种方案的成本和效益还应该在充分权衡各种方案的利弊的基础上,推荐一个较好的系统 (最佳方案),并且制定实现所推荐的系统的详细计划。如果用户接受分析员推荐的系统则可以着手完成本阶段的另一项主要工作。

  上面的 工作确定了解决问题的策略以及目标系统需要哪些程序但是怎样设计这些程序呢结构设计的一条基本原理就是程序应该模块化也就是一个大程序应该由许多 规模适中的模块按合理的层次结构组织而成。总体设计阶段的第二项主要任务就是设计软件的结构也就是确定程序由哪些模块组成以及模块间的关系。通常用层次 图或结构图描绘软件的结构。

  总体设计阶段以比较抽象概括的方式提出了解决问题的办法。详细设计阶段的任务就是把解法具体化也就是回答下面这个关键问题“应该怎样具体地实现这个系统呢”

  这个阶段的任务还不是编写程序而是设计出程序的详细规格说明。这种规格说明的作用很类似于其他工程领域中工程师经常使用的工程蓝图它们应该包含必要的细节程序员可以根据它们写出实际的程序代码。

  程序员应该根据目标系统的性质和实际环境选取一种适当的高级程序设计语言必要时用汇编语言把说细设计的结果翻译成用选定的语言书写的程序并且仔细测试编写出的每一个模块。

  这个阶段的关键任务是通过各种类型的测试及相应的调试使软件达到预定的要求。

  最基本的测试是集成测试和验收测试。所谓集成测试是根据设计的软件结构把经过单元测试检验的模块按某种选定的策略装配起来在装配过程中对程序进行必 要的测试。所谓验收测试则是按照规格说明书的规定通常在需求分析阶段确定由用户或在用户积极参加下对目标系统进行验收。

  为了使用户能够积极参加验收测试并且在系统投入生产性运行以后能够正确有效地使用这个系统通常需要以正式的或非正式的方式对用户进行培训。

  通过对软件测试结果的分析可以预测软件的可靠性反之根据对软件可靠性的要求也可以决定测试和调试过程什么时候可以结束。

  应该用正式的文档资料把测试计划、详细测试方案以及实际测试结果保存下来做为软件配置的一个组成成分。

  维护阶段的关键任务是通过各种必要的维护活动使系统持久地满足用户的需要。

  通常有四类维护活动改正性维护也就是诊断和改正在使用过程中发现的软件错误适应性维护即修改软件以适应环境的变化完善性维护即根据用户的要求改进或扩充软件使它更完善预防性维护即修改软件为将来的维护活动预先做准备。

  虽然没有把维护阶段进一步划分成更小的阶段但是实际上每一项维护活动都应该经过提出维护要求或报告问题分析维护要求提出维护要求提出维护方 案审批维护方案确定维护计划修改软件设计修改程序测试程序复查验收等一系列步骤因此实质上是经历了一次压缩和简化了的软件定义和开发的全过 程。

  大概总结一下:就是一个研究如何让软件开发的过程变得更加规范,可控,流程化,工厂化的研究体系。 如果你有耐心且想深刻了解,可以继续往下看: 学了这么长时间的

  的理解和感受,希望对各位有所帮助和借鉴。如果大家有更好的想法也希望能够提出来一起交流。 首先谈谈...

  软件危机: 60年代中期以前:通用硬件相当普遍,软件却是为某个具体的应用而编写的。 60年代中到70年代中:软件作坊。软件危机:计算机软件的开发和维护过程中所遇到的一系列严重问题。(正常、不正常运行软件都具有这种问题) 软件危机原因: 1)软件本身特点造成; 2)软件开发与维护的方法不正确。 主要表现: (a)忽视软件需求分析; (b)认为软件开发就是写程

  假设你被任命为一家软件公司的项目负责人,你的工作是管理该公司被广泛应用的字处理软件的新版本开发。由于市场竞争激烈,公司规定了严格的完成期限并已经对外公布。你打算采用哪种生命周期模型?为什么? 参考答案 项目已经对外公布完成的日期,因此必须考虑哪种模型有助于加快产品的开发进度。增量模型开发软件时可以并行完成每个增量的开发工作,能够加快进度。 因字处理软件已经广泛应用,可知:1.旧版本相当于原型...

  1.软件是无处不在的 按用途分为系统软件和应用软件以及游戏软件 我们用win7,win10就是系统软件,打王者荣耀就是游戏软件,使用wps就是应用软件,甚至我们家里的电冰箱,它身上也安装着软件!! 万物感知化,互联化,智能化, 这三个词语非常的高端,我的理解很简单,就是手机可以自动调节亮度,照相机可以自动对焦,都是有传感器啊,非生命也能感知到我们的世界了,互联化就是小米家居嘛,are you ok? 工程的意思就是把理论与实践结合,目的是有效的解决实际问题,挣钱!! 2.软件

  毕业设计 题目汇总 【不断更新中】 1.微信小程序 校园表白墙微信小程序 2.房屋租赁管理系统 3.航空售票管理系统 4.高校会议室管理系统 5.高校就业管理系统 6.失物招领系统 7.图书销售系统 8.微信小程序 商城系统 9.微信小程序 资料分享系统 10.微信小程序 校园点歌系统 11.校园资料分享系统 12.电影网站系统 13.人事管理系统 14.视频教学网站 15.网...

  1 软件与软件危机 1.1 软件的特性 软件是一种逻辑实体,而非具体的物理实体; 软件产品的生产主要是研制; 软件具有“复杂性”,其开发和运行常受到计算机系统的限制; 软件成本昂贵,其开发方式目前未完全摆脱手工生产方式; 软件不存在磨损和老化问题,但是存在退化问题。 软件产品一般分为两类:通用软件产品(如数据库软件、文字处理软件、绘图软件、工程管理工具)和定制软件产品(如电子设备的控制软...

  概论 软件的定义及特点 1单选(2分)软件产品与物质产品有很大的区别,软件产品是一种(C)产品。 A.有形 B.消耗 C.逻辑 D.文档 2多选(2分)下列关于软件的说法正确的是(BCD) A.软件是通过定制进而生产制造出来的 软件是设计开发的,而不是生产制造的 B.软件没有磨损老化问题。 C.软件开发的成本很高 D.软件开发和运行必须依赖计算机环境 3多选(2分)下列软件属于系统...

  博主 能不能分享一下,这些东西学习的资源,感觉有好多官方文档上没有,书上也学不到

  什么叫做Web开发的就对互联网很不熟悉? 什么鬼观点!!!

<
>
关于我们
AB模版网成立于2014年,我们是一家专注用户体验设计开发与互联网品牌建设的设计公司,创立至今为2000多位客户提供了创新与专业的设计方案。设计服务范围包括:交互原型设计、产品视觉设计、网站设计与开发建设、移动及软件产品界面设计、图标设计、品牌及平面设计等。

联系我们

服务时间:9:00-18:00)

官方微信官方微信

部门热线

前   台:
业务部:
客服部:
技术部:
人事部:

咨询电话 返回顶部
返回顶部