软件生存周期(SDLC,软件生命周期)是软件的产生直到报废的生命周期,周期内有问题定义、可行性分析、总体描述、系统设计、编码、调试和测试、验收与运行、维护升级到废弃等阶段,这种按时间分程的思想方法是软件工程中的一种思想原则,即按部就班、逐步推进,每个阶段都要有定义、工作、审查、形成文档以供交流或备查,以提高软件的质量。但随着新的面向对象的设计方法和技术的成熟,软件生命周期设计方法的指导意义正在逐步减少。
论述软件生存周期的几个阶段及各阶段应解决什么问题
填空: 瀑布模型的生命周期的几个阶段中, (需求分析阶段 )环节出现问题对软件的影响大。
软件生存周期为什么要划分阶段
软件生命周期(SDLC,Systems Development Life Cycle,SDLC)是软件的产生直到报废或停止使用的生命周期.周期内有问题定义、可行性分析、总体描述、系统设计、编码、调试和测试、验收与运行、维护升级到废弃等阶段,这种按时间分程的思想方法是软件工程中的一种思想原则,即按部就班、逐步推进,每个阶段都要有定义、工作、审查、形成文档以供交流或备查,以提高软件的质量。但随着新的面向对象的设计方法和技术的成熟,软件生命周期设计方法的指导意义正在逐步减少。
阶段
同任何事物一样,一个软件产品或软件系统也要经历孕育、诞生、成长、成熟、衰亡等阶段,一般称为软件生存周期(软件生命周期)。把整个软件生存周期划分为若干阶段,使得每个阶段有明确的任务,使规模大,结构复杂和管理复杂的软件开发变的容易控制和管理。通常,软件生存周期包括:
一,问题定义。要求系统分析员与用户进行交流,弄清“用户需要计算机解决什么问题”然后提出关于“系统目标与范围的说明”,提交用户审查和确认。
二,可行性研究。一方面在于把待开发的系统的目标以明确的语言描述出来,另一方面从经济、技术、法律等多方面进行可行性分析。
三,需求分析。弄清用户对软件系统的全部需求,编写需求规格说明书和初步的用户手册,提交评审。
四,开发阶段。开发阶段由三个阶段组成:
1,设计
2,实现:根据选定的程序设计语言完成源程序的编码。
3,测试
五,维护:维护包括四个方面
1,改正性维护:在软件交付使用后,由于开发测试时的不彻底、不完全、必然会有一部分隐藏的错误被带到运行阶段,这些隐藏的错误在某些特定的使用环境下就会暴露。
2,适应性维护:是为适应环境的变化而修改软件的活动。
3,完善性维护[1] :是根据用户在使用过程中提出的一些建设性意见而进行的维护活动。
4,预防性维护:是为了进一步改善软件系统的可维护性和可靠性,并为以后的改进奠定基础。
相关的软件工程国家标准把软件生存周期划分为8个阶段,是那8个阶段?
软件工程
软件工程一直以来都缺乏一个统一的定义,很多学者、组织机构都分别给出了自己的定义:
Boehm:运用现代科学技术知识来设计并构造计算机程序及为开发、运行和维护这些程序所必需的相关文件资料。
IEEE:软件工程是开发、运行、维护和修复软件的系统方法。
Fritz Bauer:建立并使用完善的工程化原则,以较经济的手段获得能在实际机器上有效运行的可靠软件的一系列方法。
软件工程(SoftWare Engineering)的框架可概括为:目标、过程和原则。
(1)软件工程目标:生产具有正确性、可用性以及开销合宜的产品。正确性指软件产品达到预期功能的程度。可用性指软件基本结构、实现及文档为用户可用的程度。开销合宜是指软件开发、运行的整个开销满足用户要求的程度。这些目标的实现不论在理论上还是在实践中均存在很多待解决的问题,它们形成了对过程、过程模型及工程方法选取的约束。
(2)软件工程过程:生产一个最终能满足需求且达到工程目标的软件产品所需要的步骤。软件工程过程主要包括开发过程、运作过程、维护过程。它们覆盖了需求、设计、实现、确认以及维护等活动。需求活动包括问题分析和需求分析。问题分析获取需求定义,又称软件需求规约。需求分析生成功能规约。设计活动一般包括概要设计和详细设计。概要设计建立整个软件系统结构,包括子系统、模块以及相关层次的说明、每一模块的接口定义。详细设计产生程序员可用的模块说明,包括每一模块中数据结构说明及加工描述。实现活动把设计结果转换为可执行的程序代码。确认活动贯穿于整个开发过程,实现完成后的确认,保证最终产品满足用户的要求。维护活动包括使用过程中的扩充、修改与完善。伴随以上过程,还有管理过程、支持过程、培训过程等。
(3)软件工程的原则是指围绕工程设计、工程支持以及工程管理在软件开发过程中必须遵循的原则。
软件工程必须遵循什么原则
围绕工程设计、工程支持以及工程管理已提出了以下四条基本原则:
(1)选取适宜的开发模型
该原则与系统设计有关。在系统设计中,软件需求、硬件需求以及其它因素间是相互制约和影响的,经常需要权衡。因此,必需认识需求定义的易变性,采用适当的开发模型,保证软件产品满足用户的要求。
(2)采用合适的设计方法
在软件设计中,通常需要考虑软件的模块化、抽象与信息隐蔽、局部化、一致性以及适应性等特征。合适的设计方法有助于这些特征的实现,以达到软件工程的目标。
(3)提供高质量的工程支撑
工欲善其事,必先利其器。在软件工程中,软件工具与环境对软件过程的支持颇为重要。软件工程项目的质量与开销直接取决于对软件工程所提供的支撑质量和效用。
(4)重视软件工程的管理
软件工程的管理直接影响可用资源的有效利用,生产满足目标的软件产品以及提高软件组织的生产能力等问题。因此,仅当软件过程予以有效管理时,才能实现有效的软件工程。
软件工程是指导计算机软件开发和维护的工程学科。
采用工程的概念、原理、 技术和方法来开发与维护软件,把经过时间考验而证明正确的管理技术和当前能够 得到的最好的技术方法结合起来,这就是软件工程。
软件工程强调使用生存周期方法学和各种结构分析及结构设计技术。它们是
在七十年代为了对付应用软件日益增长的复杂程度、漫长的开发周期以及用户对
软件产品经常不满意的状况而发展起来的。人类解决复杂问题时普遍采用的一个策
略就是“各个击破”,也就是对问题进行分解然后再分别解决各个子问题的策略
。软件工程采用的生存周期方法学就是从时间角度对软件开发和维护的复杂问题
进行分解,把软件生存的漫长周期依次划分为若干个阶段,每个阶段有相对独立
的任务,然后逐步完成每个阶段的任务。采用软件工程方法论开发软件的时候,
从对任务的抽象逻辑分析开始,一个阶段一个阶段地进行开发。前一个阶段任务
的完成是开始进行后一个阶段工作的前提和基础,而后一阶段任务的完成通常是
使前一阶段提出的解法更进一步具体化,加进了更多的物理细节。每一个阶段的开
始和结束都有严格标准,对于任何两个相邻的阶段而言,前一阶段的结束标准就
是后一阶段的开始标准。在每一个阶段结束之前都必须进行正式严格的技术审查
和管理复审,从技术和管理两方面对这个阶段的开发成果进行检查,通过之后这
个阶段才算结束;如果检查通不过,则必须进行必要的返工,并且返工后还要再
经过审查。审查的一条主要标准就是每个阶段都应该交出“最新式的”(即和所
开发的软件完全一致的)高质量的文档资料,从而保证在软件开发工程结束时有
一个完整准确的软件配置交付使用。文档是通信的工具,它们清楚准确地说明了
到这个时候为止,关于该项工程已经知道了什么,同时确立了下一步工作的基础
。此外,文档也起备忘录的作用,如果文档不完整,那么一定是某些工作忘记做
了,在进入生存周期的下一阶段之前,必须补足这些遗漏的细节。在完成生存周
期每个阶段的任务时,应该采用适合该阶段任务特点的系统化的技术方法——结
构分析或结构设计技术。
把软件生存周期划分成若干个阶段,每个阶段的任务相对独立,而且比较简
单,便于不同人员分工协作,从而降低了整个软件开发工程的困难程度;在软件
生存周期的每个阶段都采用科学的管理技术和良好的技术方法,而且在每个阶段
结束之前都从技术和管理两个角度进行严格的审查,合格之后才开始下一阶段的
工作,这就使软件开发工程的全过程以一种有条不紊的方式进行,保证了软件的
质量,特别是提高了软件的可维护性。总之,采用软件工程方法论可以大大提高
软件开发的成功率,软件开发的生产率也能明显提高。
目前划分软件生存周期阶段的方法有许多种,软件规模、种类、开发方式、
开发环境以及开发时使用的方法论都影响软件生存周期阶段的划分。在划分软件
生存周期的阶段时应该遵循的一条基本原则就是使各阶段的任务彼此间尽可能相
对独立,同一阶段各项任务的性质尽可能相同,从而降低每个阶段任务的复杂程
度,简化不同阶段之间的联系,有利于软件开发工程的组织管理。一般说来,软
件生存周期由软件定义、软件开发和软件维护三个时期组成,每个时期又进一步
划分成若干个阶段。下面的论述主要针对应用软件,对系统软件也基本适用。
软件定义时期的任务是确定软件开发工程必须完成的总目标;确定工程的可行
性,导出实现工程目标应该采用的策略及系统必须完成的功能;估计完成该项工程
需要的资源和成本,并且制定工程进度表。这个时期的工作通常又称为系统分析
,由系统分析员负责完成。软件定义时期通常进一步划分成三个阶段,即问题定
义、可行性研究和需求分析。
开发时期具体设计和实现在前一个时期定义的软件,它通常由下述四个阶段组
成:总体设计,详细设计,编码和单元测试,综合测试。
维护时期的主要任务是使软件持久地满足用户的需要。具体地说,当软件在
使用过程中发现错误时应该加以改正;当环境改变时应该修改软件以适应新的环境
;当用户有新要求时应该及时改进软件满足用户的新需要。通常对维护时期不再
进一步划分阶段,但是每一次维护活动本质上都是一次压缩和简化了的定义和开
发过程。
下面扼要介绍软件生存周期每个阶段的基本任务和结束标准。
1问题定义
问题定义阶段必须回答的关键问题:“要解决的问题是什么?”如果不知道
问题是什么就试图解决这个问题,显然是盲目的,只会白白浪费时间和金钱,最
终得出的结果很可能是毫无意义的。尽管确切地定义问题的必要性是十分明显的
,但是在实践中它却可能是最容易被忽视的一个步骤。
通过问题定义阶段的工作,系统分析员应该提出关于问题性质、工程目标和
规模的书面报告。通过对系统的实际用户和使用部门负责人的访问调查,分析员
扼要地写出他对问题的理解,并在用户和使用部门负责人的会议上认真讨论这份
书面报告,澄清含糊不精的地方,改正理解不正确的地方,最后得出一份双方都
满意的文档。
问题定义阶段是软件生存周期中最简短的阶段,一般只需要一天甚至更少的
时间。
2可行性研究
这个阶段要回答的关键问题:“对于上一个阶段所确定的问题有行得通的解
决办法吗?”为了回答这个问题,系统分析员需要进行一次大大压缩和简化了的
系统分析和设计的过程,也就是在较抽象的高层次上进行的分析和设计的过程。
可行性研究应该比较简短,这个阶段的任务不是具体解决问题,而是研究问题的范
围,探索这个问题是否值得去解,是否有可行的解决办法。
在问题定义阶段提出的对工程目标和规模的报告通常比较含糊。可行性研究
阶段应该导出系统的高层逻辑模型(通常用数据流图表示),并且在此基础上更
准确、更具体地确定工程规模和目标。然后分析员更准确地估计系统的成本和效
益,对建议的系统进行仔细的成本/效益分析是这个阶段的主要任务之一。
可行性研究的结果是使用部门负责人做出是否继续进行这项工程的决定的
重要依据,一般说来,只有投资可能取得较大效益的那些工程项目才值得继续进
行下去。可行性研究以后的那些阶段将需要投入要多的人力物力。及时中止不值
得投资的工程项目,可以避免更大的浪费。
3需求分析
这个阶段的任务仍然不是具体地解决问题,而是准确地确定“为了解决这个问题,
目标系统必须做什么”,主要是确定目标系统必须具备哪些功能。
用户了解他们所面对的问题,知道必须做什么,但是通常不能完整准确地表
达出他们的要求,更不知道怎样利用计算机解决他们的问题;软件开发人员知道
怎样使用软件实现人们的要求,但是对特定用户的具体要求并不完全清楚。因此系统
分析员在需求分析阶段必须和用户密切配合,充分交流信息,以得出经过用户确
认的系统逻辑模型。通常用数据流图、数据字典和简要的算法描述表示系统的逻
辑模型。
在需求分析阶段确定的系统逻辑模型是以后设计和实现目标系统的基础,因
此必须准确完整地体现用户的要求。系统分析员通常都是计算机软件专家,技术
专家一般都喜欢很快着手进行具体设计,然而,一旦分析员开始谈论程序设计的
细节,就会脱离用户,使他们不能继续提出他们的要求和建议。较件工程使用的结
构分析设计的方法为每个阶段都规定了特定的结束标准,需求分析阶段必须提供完
整准确的系统逻辑模型,经过用户确认之后才能进入下一个阶段,这就可以有
效地防止和克服急于着手进行具体设计的倾向。
4总体设计
这个阶段必须回答的关键问题是:“概括地说,应该如何解决这个问题?”
首先,应该考虑几种可能的解决方案。列如,目标系统的一些主要功能是用
计算机自动完成还是用人工完成;如果使用计算机,那么是使用批处理方式还是
人机交互方式;信息存储使用传统的文件系统还是数据库……。通常至少应该考虑
下述几类可能的方案:
低成本的解决方案。系统只能完成最必要的工作,不能多做一点额处的工
作。
中等成本的解决方案。这样的系统不仅能够很好地完成预定的任务,使用
起来很方便,而且可能还具有用户没有具体指定的某些功能和特点。虽然用户没
有提出这些具体要求,但是系统分析员根据自己的知识和经验断定,这些附加的
能力在实践中将证明是很有价值的。
高成本的“十全十美”的系统。这样的系统具有用户可能希望有的所有功
能和特点。
系统分析员应该使用系统流程图或其他工具描述每种可能的系统,估计每种
方案的成本和效益,还应该在充分权衡各种方案的利弊的∩希萍鲆桓鼋虾?nbsp;
的系统(最佳方案),并且制定实现所推荐的系统的详细计划。如果用户接受分
析员推荐的系统,则可以着手完成本阶段的另一项主要工作。
上面的工作确定了解决问题的策略以及目标系统需要哪些程序,但是,怎样设
计这些程序呢?结构设计的一条基本原理就是程序应该模块化,也就是一个大程
序应该由许多规模适中的模块按合理的层次结构组织而成。总体设计阶段的第二
项主要任务就是设计软件的结构,也就是确定程序由哪些模块组成以及模块间的
关系。通常用层次图或结构图描绘软件的结构。
5详细设计
总体设计阶段以比较抽象概括的方式提出了解决问题的办法。详细设计阶段
的任务就是把解法具体化,也就是回答下面这个关键问题:“应该怎样具体地实现这
个系统呢?”
这个阶段的任务还不是编写程序,而是设计出程序的详细规格说明。这种规
格说明的作用很类似于其他工程领域中工程师经常使用的工程蓝图,它们应该
包含必要的细节,程序员可以根据它们写出实际的程序代码。
通常用HIPO图(层次图加输入/处理/输出图)或PDL语言(过程设计语言
)描述详细设计的结果。
6编码和单元测试
这个阶段的关键任务是写出正确的容易理解、容易维护的程序模块。
程序员应该根据目标系统的性质和实际环境,选取一种适当的高级程序设计
语言(必要时用汇编语言),把说细设计的结果翻译成用选定的语言书写的程序
,并且仔细测试编写出的每一个模块。
7综合测试
这个阶段的关键任务是通过各种类型的测试(及相应的调试)使软件达到预定
的要求。
最基本的测试是集成测试和验收测试。所谓集成测试是根据设计的软件结构
,把经过单元测试检验的模块按某种选定的策略装配起来,在装配过程中对程
序进行必要的测试。所谓验收测试则是按照规格说明书的规定(通常在需求分析
阶段确定),由用户(或在用户积极参加下)对目标系统进行验收。
必要时还可以再通过现场测试或平行运行等方法对目标系统进一步测试检验。
为了使用户能够积极参加验收测试,并且在系统投入生产性运行以后能够正确
有效地使用这个系统,通常需要以正式的或非正式的方式对用户进行培训。
通过对软件测试结果的分析可以预测软件的可靠性;反之,根据对软件可靠
性的要求也可以决定测试和调试过程什么时候可以结束。
应该用正式的文档资料把测试计划、详细测试方案以及实际测试结果保存下
来,做为软件配置的一个组成成分。
8软件维护
维护阶段的关键任务是,通过各种必要的维护活动使系统持久地满足用户的
需要。
通常有四类维护活动:改正性维护,也就是诊断和改正在使用过程中发现的
软件错误;适应性维护,即修改软件以适应环境的变化;完善性维护,
即根据用户的要求改进或扩充软件使它更完善;预防性维护,即修改软件为将来
的维护活动预先做准备。
虽然没有把维护阶段进一步划分成更小的阶段,但是实际上每一项维护活动
都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出
维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,
复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开
发的全过程。
都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出
维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,
复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开
发的全过程。
参考资料:"
还不错,希望你采纳。
可将软件生存周期划分为哪3段个过程和哪9个阶段
一个软件从开始计划起,到废弃不用止,称为软件生存周期。一般来说,软件生存周包括计划、开发、运行三个时期,每一时期又可分为若干更小的阶段。计划时期的主要任务是分析用户要求,分析新系统的主要目标以及开发该系统的可行性。开发时期要完成设计和实现两大任务具体。具体分为需求分析、概要设计、详细设计、编码、测试。其中编码和测试是软件开发期的最后两个阶段。运行时期是软件生存周期的最后一个时期,软件人员在这一时期的工作,主要是做好软件维护。
统计表明,开发较大规模的软件,有40%以上的精力是耗费在测试上的,即使富有经验的程序员,也难免在编码中发生错误,何况,有写错误在设计甚至分析阶段早已埋下祸根,无论是早期潜伏下来的错误或编码中新引入的错误,若不及时排除,轻者降低软件的可靠性,重者导致整个系统的失败。为防患于未然,强调软件测试的重要性是必要的。
什么是软件生命周期?以及各个阶段的主要任务是什么?
1. 软件开发过程——生命周期各个阶段的基本任务
1)软件定义
(1) 问题定义
(2) 可行性研究
(3) 需求分析——系统必需完成哪些任务
2)软件开发
(1) 总体设计――概括地说,系统如何实现
(2) 详细设计
(3) 编码和单元测试
(4) 综合测试
3)软件维护
(1) 改正性维护
(2) 适应性维护
(3) 完善性维护
(4) 预防性维护
2. 实训题目:
企业客户管理信息系统
3. 系统需求:
?? 应用背景:
企业的客户管理是公司管理的一个重要内容。随着市场竞争日趋激烈,如果能拥有更多的客户,将是企业长久生存的最终因素。
维护客户信息的工作,就是要保存企业客户的基本信息,如公司名称、地址、主要行业、联系人的姓名、地址等。并要能保持一个动态的信息,确保信息的一致性。为了尽可能的保护客户信息,所以系统可以删除公司的信息,但是不删除个人的信息,这样就可以维护最多的客户。如果维护客户信息的工作只用人力来完成的话,中间就会出现很多问题,首先就是浪费人力,当企业的客户数量达到一个级别后,仅仅靠人力来维护庞大的客户信息是不可能的。如果有一个可以自动化、系统化的维护企业客户信息的管理系统,将能够为企业提供非常大的帮助。
企业管理信息系统的对象是企业、企业化管理的事业单位。
客户管理系统为企事业单位提供保存信息、修改信息、信息咨询等服务。
传统的纸介材料的数据信息管理已经不适合当代企业公司的发展了,实现客户管理的系统化、规范化、自动化,将成为当代公司管理客户信息的首选。
本系统提供了一个通用的、需要维护的客户信息。系统灵活使用表格对各种信息分门别类,组成企业客户管理系统,便于查询、阅读、修改、交流和重复使用。
?? 功能要求:
本系统的目的是帮助企业提高工作效率以及确保客户信息的准确性和实时性,实现企业客户信息管理的系统化、规范化和自动化。根据这个目的和任务,系统的主要功能是:
1. 系统管理部分:
a) 以管理员身份登陆系统后,可以添加其他用户
b) 不论何种用户登陆后都可以修改自己的密码
2. 个人信息管理部分:
a) 添加个人信息:包括姓名、性别、年龄、生日、所属公司、职务、所在国家、城市、通信地址、电话、传真、email等信息
b) 修改个人信息:修改所有的个人信息
c) 查询个人信息:按公司查询个人信息
3. 企业信息管理部分:
a) 添加企业信息:包括公司名称、所在国家、主要经营领域、与本公司合作领域、地址、电话、传真等信息
b) 修改企业信息:修改公司的各种信息
c) 查询企业信息:根据经营领域查询企业信息
d) 删除企业信息:删除不作为客户的企业信息
4. 数据管理
a) 导出客户信息Word或Excel格式的文档
b) 打印客户信息
?? 性能要求:
?? 对于合理的情况要实现
?? 对于不合理的情况程序要能够作出响应
?? 程序中用到的控件一律采用缩写的方式,具体参照课本,例如Command1用作添加信息的按钮,改名为cmdAdd,目的使得看见对象名字就知道它是什么控件、有什么功能
?? 要求做成菜单系统
?? 对于菜单所在的主窗体,要求是MDI窗体
?? 如果感兴趣大家可以尝试添加工具栏或右键菜单
4. DATA控件
5. ADO控件
6. ADO对象
7. MSFlexGrid控件的使用
软件生命周期各阶段的任务是什么
1. 软件开发过程——生命周期各个阶段的基本任务
1)软件定义
(1) 问题定义
(2) 可行性研究
(3) 需求分析——系统必需完成哪些任务
2)软件开发
(1) 总体设计――概括地说,系统如何实现
(2) 详细设计
(3) 编码和单元测试
(4) 综合测试
3)软件维护
(1) 改正性维护
(2) 适应性维护
(3) 完善性维护
(4) 预防性维护
“软件生存周期过程”概念进一步完善了关于软件生存周期的定义,其主要内容是?
软件工程的传统途径是"生命周期法",强调"结构化分析,结构化设计".
1. "生命周期法"的起源
人类解决复杂问题时普遍采用的一个策略是"各个击破",也就是对问题进行分解,然后再分别解决各个子问题的策略.
软件工程采用的"生命周期法",就是从时间角度对软件开发和维护的复杂问题进行分解,把软件生存的漫长周期依次划分为若干个阶段,每个阶段有相对独立的任务,然后再逐步完成每个阶段的任务.
2.1 软件生命周期
2. 生命周期划分的原则
各阶段的任务彼此间尽可能相对独立,同一个阶段各项任务的性质尽可能相同,从而降低每个阶段任务的复杂性,简化不同阶段之间的联系,有利于软件开发过程的组织管理.
3. 生命周期的划分
软件生命周期一般分为:软件定义(问题定义,可行性研究,需求分析),软件开发(总体设计,详细设计,编码和单元测试,综合测试),软件使用与维护等三个时期.
生命周期法各阶段的工作小结
生命周期法各阶段的工作小结
2.1 软件生命周期
4. "生命周期法"的特点
阶段具有顺序性和依赖性
推迟实现的观点
质量保证的观点
每个阶段都必须完成规定的文档
每个阶段结束前都要对所完成的文档进行评审,以便尽早发现问题,改正错误.
转载请注明出处51数据库 » 软件生存周期各阶段任务 软件生存周期可以分为几个阶段