第三次博客作业

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

 

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

/**

     *

     * 该方法根据用户输入取出中间的电话号码部分

     * @paramstrPhoneNum电话号码,如:“0591-83279988—002”

     * @return返回号码部分,如:“83279988”

     */

public String getPhoneNumber(String strPhoneNum){

if((strPhoneNum==null) || "".equals(strPhoneNum)){

return "";

        }

String[] arrPhone=strPhoneNum.split("-");

returnarrPhone[1];

    }

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

(1)写出问题所在:

问题1:没有考虑到输入格式的完整性,如果格式不满足xxxx-xxxxxxxx—xxx这样的格式,都会出错。

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

上述代码只描述了if((strPhoneNum==null)||””.equals(strPhoneNum))时有返回值。如果出现的strPhoneNum!=null时则系统会出现错误。

(3)

 

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

要求:

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

packagecn.zhou.d;

 

importjava.util.Scanner;

 

public class Demo {

   publicstaticvoid main(String[] args) {

     

      int[] data=newint[5];

      Scanner sc=newScanner(System.in);

      System.out.println("请输入5个数: ");

      for(inti=0;i<5;i++){

         intnum=sc.nextInt();

         data[i]=num;

      }

      dd.selectSort(data);

   }

   staticvoidselectSort(int data[])

   {

      intk,temp;

      for(inti=1;i<=data.length-1;i++)

      {

         k=i-1;

         //找到最小的数的下标,记入k中

         for(int j=i;j<=data.length-1;j++)

         {

            if(data[j]<data[k])

            {

                k=j; 

            }

         }

         //将最小的数和第i个数交换

         temp=data[i-1];

         data[i-1]=data[k];

         data[k]=temp;  

      }

      for(inti=0;i<data.length;i++){

         System.out.println(data[i]);

      }

   }

(2)说明你的设计思路

搜索整个值列,以找到最小值。将该值与值列中第一个位置上的值进行交换。搜索剩下的值列(第一个除外),以找到其中的最小值,然后将其与值列中第二个位置上的值进行交换。对值列中的每个位置重复该过程。在算法结束时,就完成了对值列的排序

出错的情况(至少五种)

  1. 如果有2个相同值可能会出错
  2. 如果测试的数组位数太大可能会出错
  3. 如果有2个相同的最小值可能会出错
  4. For循环可能会出错

posted on 2016-04-29 15:40  echo1561  阅读(119)  评论(0编辑  收藏  举报