在软件测试中,错误,故障,失效有何不同

 我来答
千锋教育
2017-06-29 · 做真实的自己 用良心做教育
千锋教育
千锋教育专注HTML5大前端、JavaEE、Python、人工智能、UI&UE、云计算、全栈软件测试、大数据、物联网+嵌入式、Unity游戏开发、网络安全、互联网营销、Go语言等培训教育。
向TA提问
展开全部
在日常的软件测试过程中,经常会碰到软件相关的问题,不同的人对问题的称呼也不同,比如错误(mistake或者error)、缺陷(defect)、失效/失败(fail或failure)等。这些不同的术语,虽然在平时讨论的时候,可能含义基本上是一样的,都是指软件中存在的一些问题。但是它们的具体含义和定义是不一样的。根据IEEE 1990中对这些术语的定义,可以帮助我们更好的理解它们的真正含义和它们之间的相互关系:
● 错误(mistake):产生不正确结果的人为行为。人为的原因导致一个不正确的结果。它可以是程序内的内部错误,也可能是文档内的错误。甚至是环境方面的问题。
● 错误(error):计算机计算得到的、观察到的、测量到的数值或者条件和理论上得到的正确的数值或者条件之间存在的差异。
● 缺陷(defect):程序或者软件中不正确的步骤、过程或者数据定义等。比如错误的语句或者错误的标量定义等。缺陷是错误的具体表现,可以是不正确的文档、程序段以及指令或者数据定义。
● 失效/失败(failure/fail):软件系统或单元无法实现需求文档中规定的功能特性或者非功能特性。或者说单元/系统产生的结果与期望交付的服务或者结果存在偏差。外部的失效/失败是内部缺陷在执行测试软件时的外部反映。它是规范说明的期望值与实际观察到的值、现象等存在偏差。比如不正确的系统反应、系统崩溃、系统死机等等。
人为造成的错误(mistake)引入到软件工作产品中就变成了缺陷(fault或defect),或者环境因素导致软件中存在瑕疵。其中的软件工作产品包括软件生命周期中的任何输出,比如规格说明、设计文档或者代码等等。这些错误,引入到软件工作产品中后,就成为了软件的缺陷。假如存在缺陷的代码,进行了运行,这些缺陷就可能会导致系统的不正常,或者导致系统的失效和失败。运行存在缺陷的软件系统,并不一定会产生运行错误或对用户产生消极的影响,即失效。一个缺陷的存在不一定会产生失效,而有的缺陷可以产生非常多的失效。
软件系统的失效/失败只是表面现象,我们测试的目的之一是发现失效/失败。而对于开发人员,重要的是通过开发活动来发现和消除引起失效/失败的存在软件中的缺陷。发现缺陷(引起软件失效的一个根源)的过程需要花费时间和成本,同时也存在不确定性。同时错误(error)是用来测量得到的结果不正确的程度。
软件中的失效/失败的演化过程如下面的图示。测试的一个重要目的是让软件系统失败,从而来发现软件中存在的缺陷,在软件提交给客户之前可以将缺陷修改。测试的另一个重要目的是评估软件的整体的质量。比如,假如软件系统中存在太多的高严重度的缺陷,测试团队可以将软件系统打回开发团队,要求他们改进软件产品质量。在软件质量改进之前,测试团队没有必要浪费时间来继续测试执行活动。或者提供管理人员一些软件产品质量的信息,可以帮助他们确定软件产品的质量是不是可以提交给用户使用,还是需要继续花费时间和成本继续测试活动,以发现更多的缺陷。
残题材俏
2017-06-27 · TA获得超过145个赞
知道答主
回答量:149
采纳率:100%
帮助的人:47.4万
展开全部
横看成岭侧成峰,远近高低各不同.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式