实验四
Posted 云s
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实验四相关的知识,希望对你有一定的参考价值。
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) 写出问题所在
1、如果用户输入号码没有以‘—’隔开,返回的号码是错的
2、电话号码没有输入控制(如:输入的只能是数字,位数有限制)
(2) 写出问题产生的原因
此代码要求用户号码输入的格式必须正确,却没有对用户电话号码输入的格式进行提示,用户容易输入不正确的格式,导致返回的电话号码错误。
(3) 给出修改后的代码
/**
* 该方法根据用户输入取出中间的电话号码部分
* @param strPhoneNum 电话号码,如:“0591-83279988—002”
* @return 返回号码部分,如:“83279988”
*/
public class Test {
public String getPhoneNumber(String strPhoneNum){
String way = null;
//提示输入的格式
System.out.println("输入(区号-电话号码-分机号)");
if((strPhoneNum == null)|| "".equals(strPhoneNum)){
return "";
}
//输入控制
if (strPhoneNum.length() != 15) {
System.out.println ("电话号码必须是15位");
return "";
}
for (int i = 0; i < strPhoneNum.length(); i++) {
char p = strPhoneNum.charAt(i);
if (p < \'0\' || p > \'9\') {
System.out.println ("电话号码必须由数字组成!");
return "";
}
}
2、 请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)
要求:
(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)
/*
* 对数组进行排序的原理是:先比出最大的,再找到第二大的,直到最小的
* 将它们依次赋值给数组
*/
import java.util.Arrays;
import java.util.InputMismatchException;
import java.util.Scanner;
public class rank {
static void count(int[] arr){
int p,q,s;
System.out.println("排序后:");
for(int i=0;i<arr.length-1;i++)
{
p = i;q=arr[i];
for(int j=i+1;j<arr.length;j++)
{
if(arr[j]> q)
{
p = j;q = arr[j];
}
}
if(p != i)
{
s = arr[i];
arr[i] = arr[p];
arr[p] = s;
}
}
for(int k=0;k<arr.length;k++)
{
System.out.println( +arr[k]);
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
rank p = new rank();
final int length = 5;
int[] a = new int[length];
int i = 0;
System.out.println("请输入5个数:");
while(i<a.length)
{
try {
Scanner scanner = new Scanner(System.in);
a[i] = scanner.nextInt();
i++;
}catch (InputMismatchException e)
{
System.out.println("Invalid digit number in format, please input again!");
}
}
p.count(a);
}
}
(2) 说明你的设计思路
对数组进行排序的原理是:先比出最大的,再找到第二大的,直到最小的
将它们依次赋值给数组。 封装这个函数,在main方法调用这个函数
(3) 写出可能出错的情况(至少五种)
1、当输入不是数字时,程序是否会报错。
2、当所输入的数组很大时,程序是否能够正常运行。
3、当所输入的数是负数时,是否会正确的排序。
4、 数组为空的情况
5、数组已按逆序排好
(4) 编写JUnit单元测试,将前面给出的可能出错的测试数据放入单元测试进行测试
测试用例1:对出错情况1,测试用例为输入 k,实验结果有错误提示
测试用例2:对出错情况2和3的测试用例
Int a = {12345678,-2,-48,555,8}
实验结果ok
测试用例3:对出错情况5的测试用例,实验结果ok
以上是关于实验四的主要内容,如果未能解决你的问题,请参考以下文章