第三次博客作业

1、  某网站管理系统,用户注册时,电话号码为可选输入项,输入格式为:区号-电话号码—分机号,中间用“-”隔开。以下为jsp页面上的设计,且并未对输入做任何控制。

假设系统现在需要取出中间的电话号码部分,代码如下:

复制代码
/**
     * 
     * 该方法根据用户输入取出中间的电话号码部分
     * @param strPhoneNum  电话号码,如:“0591-83279988—002”
     * @return  返回号码部分,如:“83279988”
     */
    public String getPhoneNumber(String strPhoneNum){
        if((strPhoneNum==null) || "".equals(strPhoneNum)){
            return "";
        }
        String[] arrPhone=strPhoneNum.split("-");
        return arrPhone[1];
    }
复制代码
 

请用你学过的测试技术和方法,找出该方法中存在的问题,并且分析出现该问题的原因,同时给出你的解决方案。(提示:存在的问题不止一个)

要求:

(1) 写出问题所在

(2) 写出问题产生的原因

(3) 给出修改后的代码

答:

(1)问题:未限制可输入的号码的长度,未定义输入的是否是数字还是字符串,未验证是否为空

(2)在if语句中判断条件不足    

 public String getPhoneNumber(String strPhoneNum){
        if((strPhoneNum==null) || "".equals(strPhoneNum)){
            return "";
        }

(3)

public String getPhoneNumber(String strPhoneNum){
if((strPhoneNum==null) || "".equals(strPhoneNum)){
     if(strPhoneNum.lenth==8 && !Pattern.compile("^\\d{8}$").matcher(phoneNumber.trim
   ()).matches())){
           return "true";
}

}else{

return "false";
System.out.println("输入的号码格式不正确!!!");
}
String[] arrPhone=strPhoneNum.split("-");
return arrPhone[1];
}

split将号码拆分成三个部分

得到的结果为:

区号:0591

电话号码:83279988

分机号:002

 

2、  请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)

要求:

(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)

(2) 说明你的设计思路

(3) 写出可能出错的情况(至少五种)

(4) 编写JUnit单元测试,将前面给出的可能出错的测试数据放入单元测试进行测试

 

(1)代码:

 

package cn.wang.arr;

public class Sort {

/**
* 冒泡排序算法的实现
* 2016/04/26
* @author 王*鑫
*/

public static int[] maopao(int[] x){

//此循环是将数组的两个数进行比较,若第一个数比第二个数大则将第一个数传给第二个数
for(int i = 0 ;i<x.length ;i++){
for(int j= i+1; j<x.length; j++){
if(x[i]>x[j]){
int temp = x[i];
x[i] = x[j];
x[j] = temp;
}
}
}
for(int i:x){ //将x的值赋值给i后输出
System.out.println(i + "");
}
return x;
}
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] i={-1,0,1,4,5,6,78,9,4,2,4,11,45,-8};
System.out.println("排序后的结果为:");
maopao(i);  //调用排序maopao方法
System.out.println();
}
}

 

(2)以冒泡排序的思想进行设计,跟气泡上升的原理是一样的,依次将相临的两个数进行比较,将小的
数调到下面大的放在上面,从数组x[0]开始,依次将其和后面的元素比较,若x[i]>x[j],则交换它们,
一直比较到数组的最后一个数为止。对x[i],x[i+1],...进行处理,即可完成排序。

(3) 数组为空的情况;

       输入的数组只含一个元素;

       数组已经排好了顺序;

       数组已按逆序排好;

      数组中的部分或全部元素相同时。

(4)单元测试:

当数组为空时,控制台为空没有数字:

 

输入的数组只含一个元素时,可以看得控制台只出现一个数字:

 

  数组已经排好了顺序时:

 数组已按逆序排好时:

 

 数组中的部分或全部元素相同时:

 

转载于:https://www.cnblogs.com/wpxBlog/p/5440241.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值