软件测试作业二 —— 对于Faults,Errors,Failures的认识的习题

本文分析了两个数组索引查找算法的实现及其存在的问题。第一个算法的目标是找到数组中最后一个特定值的索引,而第二个算法则用于查找数组中的最后一个零元素。文章通过具体的例子指出了这些算法中存在的错误,并探讨了它们未能正确执行的原因。
public int findLast (int[] x, int y) {
        //Effects: If x==null throw              
        //               NullPointerException
        // else return the index of the last element
        // in x that equals y.
        // If no such element exists, return -1    
        for (int i=x.length-1; i > 0; i--)
        {
                if (x[i] == y)
                {
                        return i;
                }
        }
        return -1;
}
 // test: x=[2, 3, 5]; y = 2
// Expected = 0

首先这段代码的功能是找到数组中最后一个y的索引,如果没有就返回-1

1. 这段代码没有遍历到数组的第一个元素,也就是x[0],这是这段代码的Fault

2. x[] = {}; y=2 没有进入Fault

3. x[] = {1,2,3}; y=2 进入Fault但没有进入Error

4. x[] = {1,2,3}; y=0 进入Error但没有进入Failutre

 

public static int lastZero (int[] x) {
        //Effects: if x==null throw
        //           NullPointerException
        // else return the index of the LAST 0 in x.
        // Return -1 if 0 does not occur in x
        for (int i = 0; i < x.length; i++)
        {
                 if (x[i] == 0)
                {
                        return i;
                }
        }
        return -1;
}
// test: x=[0, 1, 0]
// Expected = 2

这段代码的功能是找到数组中的最后一个为0的索引,如果没有0的元素,就返回-1

1. 这段代码实际的功能是找数组的第一个为0的元素的索引,也就是从循环开始就是Fault

2. x[] = {}即没有进入Fault

3. x[] = {1}即进入Fault但不进入error, 即只有一个元素时,功能上第一个元素就是最后一个元素,表示没有进入error

4. x[] = {0,1,2}即进入Error但不进入failture

 

转载于:https://www.cnblogs.com/Elson8080/p/5252193.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值