如何解决了解故障,错误和故障的含义
|| 考虑以下类别:class Xyz {
public int count;
public void numZero (int[] x) {
// Effects: if x == null throw NullPointerException
// else return the number of occurrences of 0 in x
int count = 0;
for (int i = 1; i < x.length; i++) //we have a bug here
{
if (x[i] == 0)
{
count++;
}
}
this.count = count;
}
}
我想对Fault
,Error
和Failure
的真正含义进行总结。
故障
据我了解,在这种情况下,“ 1”将是代码的书面逻辑中的一个缺陷。
因此,在这种情况下,代码“ 1”将指示代码计算机以开始索引1而不是预期的0开始对“ 6”的所有元素进行迭代。
错误
当运行上述方法时,我们总是得到一个Error
,但是在一次实例中(当是v.length == 0
时),因为我们真正想要的是迭代x
的所有元素,但是由于我们是从i = 1
开始的,所以这实际上没有发生。
输入一个空向量,因为我们没有输入for loop
,所以我们的错误代码不会运行,这意味着不会发生错误,并且理论上一切都会发生。
失败
由于我们的代码有一个Fault
,在执行时几乎总是以Error
表示,因此当我们有效地看到不正确的输出时,我们只有一个Failure
。
假设在我的程序中有效地发生了ѭ2,那么只有在外部可见的情况下,我们才会出现失败。也就是说,如果我had16ѭ;而不是public int count;
,我永远不会在我的课堂上出现错误(当然,这是有史以来最无用的课堂!)。这是正确的吗?
我说的一切正确还是我犯了错?
谢谢
解决方法
失败:与预期结果不同。这就是问题
你观察。
故障:故障原因。
错误:导致故障发生的错误。例如错别字。
故障,错误和错误的示例。
pre: param is an integer.
post: returns the product of the param multiplied by 2.
1. int double (int param) {
2. int result;
3. result = param * param;
4. return result;
5. }
•对double(3)的调用返回9,但后置条件表明应返回6。
•结果9表示失败。
•故障是由于第3行的故障引起的((使用\“ * param \”代替\“ * 2 \”)
•错误是拼写错误(有人误输入了\“ * param \”而不是\“ * 2 \”)。
为什么要为“臭虫”提供三个不同的标签?
他们可以帮助您准确地知道问题所在。
说“失败”表示您知道有问题,但不知道原因。
说“故障”表示您知道原因,但不知道为什么发生故障。
说“错误”表示您知道发生错误的原因。例如:编码员因路过的救火车而分心。
您可能会问:“但是,为什么人要打错字呢?”,但这进入了人为因素,而且超出了问题的范围。
资料来源:约克大学软件测试部的姜振明(Jack)Jiang-EECS 4413。
, 首先,每当系统交付的实际服务偏离其预期服务时,就会发生故障。请注意,由于即使规范也会出错,因此定义不依赖于它们。
其次,错误是系统状态中可能导致故障的部分。系统状态可能会出错,但永远不会到达输出,因此不会导致故障。
第三,故障是导致错误的原因。它可能是设计错误,宇宙射线或其他任何东西。如您所指出的,如果故障未激活,则不会产生错误。
请查看可靠性的基本概念和术语,以获取更多信息。
,
错误是与实际和预期结果的偏差。它代表了人民的错误。
错误是错误的结果。这是不正确的步骤或过程,导致程序或软件意外运行
错误是程序中故障的证据,由于该程序无法按预期方式运行
故障是系统或组件无法执行其所需功能。执行故障时发生故障
发生故障时,可以检测到缺陷。
,错误/错误/故障中的错误是指引入问题的人为错误。人为错误是导致用户在示例中创建错误的for语句的错误思维。
错误很难衡量或理解。在很多情况下,很难知道开发人员在犯了错误而导致错误时会在想什么。这就是为什么他们喜欢区分错误和错误。我们可以看到代码中有错误,但是很难知道为什么会产生错误。可能是代码正确,然后在随后的更改中,for循环已更改。
我一直记得,程序员的错误会导致代码中的错误,从而导致用户失败。并非所有错误都会导致故障。并非所有故障都会导致故障。
, 软件故障是指代码中的错误。这是在软件活动期间。
软件失败是指系统行为异常时。这是在故障之后才发现的。
故障可能是导致故障的原因。错误是“ WHAT \”,失败是“ WHEN \”。
这些仅是基本原则,但我仍然希望它能使您对此有所了解。
, 有多种不同的定义,我个人更喜欢以下定义:
Fault -> Error -> Failure
故障:错误的经过验证或假设的原因(故障,外部干扰,设计错误)。
错误:程序或数据结构内故障的表现(实际输出与预期输出之间的差异)。
失败:错误到达服务接口,从而改变服务本身时发生的事件(导致系统或组件无法根据其规范执行所需的功能)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。