第三次博客作业
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) 写出问题所在
问题一:
public String getPhoneNumber (我是不知道为啥 我这个调用的时候提示我加个 static,就单个问题一好了)
问题二
只能根据用户输入的符号 “-”进行分割字段,而且提取的是第二字段,也就是说没有“-”这个符号的话就没法进行进行返回电话号码。而且根据split的用法只有出现第二个-的时候。提取的第二字段才结束。所以只出现一个-的话就出现了以下图片的问题,讲“-”之后的内容全部返回了。
问题三:
没法进行电话号码的长度判定。比如区号。电话号码。分机号的判断。
看我都输入了这么长的代码都没有报错。
(2) 写出问题产生的原因
问题一产生的原因:(百度了一下英文)原因就是我调用的时候没实例化函数 所以加一个static。这个额- -能不能算上一个错误呢= =实在是找不到更多的错误了。强行错一个吧
问题二产生的原因:根据split的用法。只有出现.split("这里的符号");才会分割新的字段出来。而且要注意的是半角跟全角是有区别的 还有中英文的符号也是有区别的--
问题三产生的原因:就是没有对arrPhone[] 进长度的判断 arrPhone[0]代表的是区号 arrPhone[1]代表的是电话号码arrPhone[2]代表的是分机号;
(3) 给出修改后的代码
// static 要去掉 这边复制过来的,就不去掉了
public static String getPhoneNumber(String strPhoneNum){
if((strPhoneNum==null) || "".equals(strPhoneNum)){
return "没有输入电话号码";
}
String[] arrPhone=strPhoneNum.split("-");
if((arrPhone[0].length()!=3)&&(arrPhone[0].length()!=4)){
return "区号书写错误";
}
else if((arrPhone[1].length()!=7)&&(arrPhone[1].length()!=8)){
return "电话号码书写错误";
}
else if(arrPhone[2].length()!=3){
return "分机号码书写错误";
}
return arrPhone[1];
}
2、 请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)
要求:
(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)
public class test2 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
//定义输入数组
int[] arg={6,6,44,66,22,33,1,23,11};
//调用arr方法
int[] arg1 =test2.arr(arg);
//输出经过arr方法换算之后的结果
for(int k = 0;k<arg1.length;k++){
System.out.print(arg1[k]+"\t");
}
}
//数组排序方法
public static int[] arr(int arr[]){
//定义一个缓冲数
int tmp;
//进行一个数组排序
for(int i=0;i<arr.length;i++){//第一层循环 先找出一个数组的元素
for (int j=0;j<arr.length;j++){//第二层循环 找出最小的元素替换排在第一位
if(arr[i]<arr[j]){//开始比较大小
tmp=arr[i];//先当前数组的元素缓存在tmp当中
arr[i]=arr[j];//然后将比较小的第二层循环数组元素替换成当前数组元素
arr[j]=tmp;//然后将缓冲在tmp中的数组元素替换回到第二层循环的数组元素中
}
}
}
return arr;//返回排序好的数组
}
}
(2) 说明你的设计思路
设计思路- -写的注释就是了。
首先先从用户端获取一组数组。为了方便操作(懒)就设置了一个默认的数组;
然后着手写arr方法也就是数组排序的方法;
想了一下还是冒泡排序比较方便。所以就用了两个循环来嵌套进行冒泡排序;
第一层循环是用来做被比较的对象的;
然后第二层循环是用来跟第一层循环进行对比的;
然后设置一个临时值充当缓冲区来临时保存数值;
返回arr数组;
打印新的数组;
(3) 写出可能出错的情况(至少五种)
原谅我不知道该怎么写可能出错的情况。因为我设置的是默认数组。出现没数字的话 就直接报错
1:输入的非数字就报错;(输入非数字我也运行不了啊- -)
2:数组元素都一样
3:实在写不出来了(要是真的有什么会错的早就改了。怎么可能让他错。让写代码的人查自己的错误实在- -找不出来)
(4) 编写JUnit单元测试,将前面给出的可能出错的测试数据放入单元测试进行测试