《Java 程序设计》课堂实践项目-Arrays和String单元测试 课后学习总结

目录

  • 改变
  • Arrays和String单元测试实验要求
  • 课堂实践成果
  • 课后思考

改变

修改了博客整体布局,改变了之前贴个截图粘个代码就糊弄完的观念,这次布局和内容都有修改。

    补充了部分没有讲过的测试类的样例,图片等都是再次运行之后截得细致的图片,电脑上也有原图。

Arrays和String单元测试实践要求

  1. 问:在IDEA中以TDD的方式对String类和Arrays类进行学习
    - 测试相关方法的正常,错误和边界情况
    - String
       - charAt
       - split
      
    - Arrays
      - sort
      - binarySearch

课堂实践成果

代码如下:

  1. import static org.junit.Assert.*;
    /** * Created by Lenovo on 2017-06-11. */ /** * Created by 20145207 on 2017/5/4. */
    import junit.framework.TestCase; import org.junit.Test;
    import java.lang.*; import java.util.Arrays;
    public class ComplexTest extends TestCase {
    Complex c1 = new Complex(0, 3);
    Complex c2 = new Complex(-1, -1);
    Complex c3 = new Complex(2, 1);
    String str = "dangranshixuanzeyuanliangtala";
    String str2 = "dang:ran:shi:xuan:ze:yuan:liang:ta:la";//String[] str2sort = str2.split(":");
    String[] str3 = new String[]{"dang", "ran", "shi", "xuan", "ze", "yuan", "liang", "ta", "la"};
    @Test public void testString_charAt() throws Exception {
    assertEquals('d', Complex.getString_charAt(str,0));
    assertEquals('g', Complex.getString_charAt(str,3));
    assertEquals('n', Complex.getString_charAt(str,6));
    }
    @Test public void testString_split() throws Exception {
    assertEquals("dang", Complex.getString_split(str2)[0]);
    assertEquals("yuan", Complex.getString_split(str2)[5]);
    assertEquals("liang", Complex.getString_split(str2)[6]);
    }
    @Test public void testgetArrays_sort() throws Exception {
    //ArraysTest(str3);
    assertEquals("dang", Complex.getArrays_sort(str3)[0]);
    assertEquals("ta", Complex.getArrays_sort(str3)[5]);
    assertEquals("xuan", Complex.getArrays_sort(str3)[6]);
    }
    @Test public void testgetArrays_binarySearch() throws Exception {
    //ArraysTest2(str4);
    assertEquals(1, Arrays.binarySearch(Complex.getArrays_binarySearch(str4), 5.4));
    assertEquals(0, Arrays.binarySearch(Complex.getArrays_binarySearch(str4), 4.6));
    assertEquals(4, Arrays.binarySearch(Complex.getArrays_binarySearch(str4), 49.2));
    }
  1.  

实验截图如下:

需要注意以下两点我做实验时遇到的问题:

  • 测试sort时输入的是字符串数组还是字符数组这里出现了问题,之后查API发现其实有很多类型。
  • 测试binarySearch是输入的是double类型的,因为上来就用了字符串数组,导致出错

课后思考

关于测试

1.正常情况我是通过随机选取三个测试用例进行测试的

2.错误情况是直接输入错误答案看是否通过测试

3.边界情况是测试数组第一个和最后一个,截图为正常情况的测试。

关于过程

1.charAT:

  • 此方法返回位于字符串的指定索引处的字符。该字符串的索引从零开始。
  • 该方法的返回指定索引处char值。
  • 所以为了实现单元测试,我在complex.java文件中添加如下代码:
  1. 代码:
    //测试一
    public static char String_charAt(String str, int i) {
        return str.charAt(i);
    }
  2.  
  3. //取测试一结果
    public static char getString_charAt(String str, int i) {
        return String_charAt(str, i);
    }

在complex.test中添加如下代码对其进行测试:

  1. @Test
    public void testString_charAt() throws Exception {
        assertEquals('d', Complex.getString_charAt(str,0));
        assertEquals('g', Complex.getString_charAt(str,3));
        assertEquals('n', Complex.getString_charAt(str,6));
    }

测试数组为:

  1. String str = "dangranshixuanzeyuanliangtala";

最后测试结果如下:

2.split

  • 这个方法有两个变体,并分割这个字符串围绕给定的正则表达式匹配。
  • 返回由分割这个字符串围绕给定的正则表达式匹配计算字符串数组。
  • 为了实现单元测试,我在Complex.java文件中添加如下代码:
  1. //测试二
    public static String[] String_split(String str) {
        String[] strsort = str.split(":");
        return strsort;
    }
  2.  
  3. //取测试二结果
    public static String[] getString_split(String str) {
        return String_split(str);
    }

在complex.java中添加如下代码对其进行测试:

  1. @Test
    public void testString_split() throws Exception {
        assertEquals("dang", Complex.getString_split(str2)[0]);
        assertEquals("yuan", Complex.getString_split(str2)[5]);
        assertEquals("liang", Complex.getString_split(str2)[6]);
    }

测试数组为:

  1. String str2 = "dang:ran:shi:xuan:ze:yuan:liang:ta:la";

最后测试结果如下:

3.sort

  • 我使用sort方法字符指定数组排序按数字升序顺序。
  • 此方法不返回任何值
  • 为了实现单元测试,我在complex.java文件中添加如下代码:
  1. //测试三
    public static String[] Arrays_sort(String[] str3) {
        Arrays.sort(str3);
        return str3;
    }
  2.  
  3. //取测试三结果
    public static String[] getArrays_sort(String[] str3) {
        return Arrays_sort(str3);
    }

在complex.java中添加如下代码对其进行测试:

  1. @Test
    public void testgetArrays_sort() throws Exception {
        //ArraysTest(str3);
        assertEquals("dang", Complex.getArrays_sort(str3)[0]);
        assertEquals("ta", Complex.getArrays_sort(str3)[5]);
        assertEquals("xuan", Complex.getArrays_sort(str3)[6]);
    }

测试数组为:

  1. String[] str3 = new String[]{"dang", "ran", "shi", "xuan", "ze", "yuan", "liang", "ta", "la"};

最后测试结果如下:

4.benarysearch

  • 方法搜索指定double数组,使用二进制搜索算法来指定值。该数组必须在进行此调用之前进行排序。如果不排序,则结果是不确定的。
  • 此方法返回搜索键的索引,如果它包含在数组中,否则它返回(- (插入点)- 1)。插入点是在将键插入数组的那一点:第一个元素比键大,或如果阵列中的所有元素都小于指定的键的索引大于a.length。
  • 为了实现单元测试,我在complex.java文件中添加如下代码:
  1. //测试四
    public static double[] Arrays_binarySearch(double[] str4) {
        Arrays.sort(str4);
        return str4;
    }
  2.  
  3. //取测试四结果
    public static double[] getArrays_binarySearch(double[] str4) {
        return Arrays_binarySearch(str4);
    }

在complextest.java中添加如下代码对其进行测试:

  1. @Test
    public void testgetArrays_binarySearch() throws Exception {
        //ArraysTest2(str4);
        assertEquals(1, Arrays.binarySearch(Complex.getArrays_binarySearch(str4), 5.4));
        assertEquals(0, Arrays.binarySearch(Complex.getArrays_binarySearch(str4), 4.6));
        assertEquals(4, Arrays.binarySearch(Complex.getArrays_binarySearch(str4), 49.2));
    }

测试数组为:

  1. double str4[] = {5.4, 4.6, 49.2, 9.2, 35.4};

最后测试结果如下:

学习反思及总结

重新做了一遍实验加深了对TDD的理解,同时也提高了对测试代码应用方面的能力,温故而知新。关于代码在上面就有总结过就不重复了。·

《Java 程序设计》课堂实践项目-Arrays和String单元测试的更多相关文章

  1. 20155322 2016-2017-2 《Java面向对象程序设计》第十二周课堂练习之Arrays和String单元测试

    20155322 2016-2017-2 <Java面向对象程序设计>第十二周课堂练习之Arrays和String单元测试 练习目地 在IDEA中以TDD的方式对String类和Array ...

  2. 20155228 2017-5-10 课堂测试:Arrays和String单元测试

    20155228 2017-5-10 课堂测试:Arrays和String单元测试 题目和要求 在IDEA中以TDD的方式对String类和Arrays类进行学习 测试相关方法的正常,错误和边界情况 ...

  3. 【课堂实验】Arrays和String单元测试

    实验内容 在IDEA中以TDD的方式对String类和Arrays类进行学习 测试相关方法的正常,错误和边界情况 String类 charAt split Arrays类 sort binarySea ...

  4. 《Java 程序设计》课堂实践项目汇总链接

    1.<Java 程序设计>课堂实践项目-命令行参数 2.<Java 程序设计>课堂实践项目-mini dc 3.<Java 程序设计>课堂实践项目-Arrays和S ...

  5. 《Java 程序设计》课堂实践项目 课后学习总结

    <Java 程序设计>课堂实践项目 课后学习总结 String类的使用(sort) 目录 Linux命令(sort) 课堂实践 课后思考 学习老师的代码之后的思考:int与Integer ...

  6. 20155320 2016-2017-2《Java程序设计》第十二周课堂实践项目

    20155320 2016-2017-2<Java程序设计>第十二周课堂实践项目 1.修改教材P98 Score2.java, 让执行结果数组填充是自己的学号: 2.在IDEA中以TDD的 ...

  7. 20155321 2016-2017-2《Java程序设计》课堂实践项目

    20155321 2016-2017-2<Java程序设计>课堂实践项目 关于String类 split方法 charAt方法 项目题目: 模拟实现Linux下Sort -t : -k 2 ...

  8. 20162318 2016-2017-2《Java程序设计》课堂实践项目

    20162318 2016-2017-2<Java程序设计>课堂实践项目 String类的使用 在String类中有一种split的方法.它可以把字符串分割为好几个小的字符串. 实践内容: ...

  9. 《Java 程序设计》课堂实践项目-类定义

    <Java 程序设计>课堂实践项目类定义 课后学习总结 目录 改变 类定义实验要求 课堂实践成果 课后思考 改变 修改了博客整体布局,过去就贴个代码贴个图很草率,这次布局和内容都有修改. ...

随机推荐

  1. PyQt4(简单布局)

    import sys from PyQt4 import QtCore, QtGui app = QtGui.QApplication(sys.argv) widget = QtGui.QWidget ...

  2. npm用法及离线安装方法

    npm用法及离线安装方法 基本的用法 查看某个模块的全部信息,或者可以查看单个信息 npm info name npm info name version npm info name homepage ...

  3. 1.Junit test使用

    1.导入maven依赖 <dependency> <groupId>junit</groupId> <artifactId>junit</arti ...

  4. 从一个简单的 JPA 示例开始

    本文主要讲述 Spring Data JPA,但是为了不至于给 JPA 和 Spring 的初学者造成较大的学习曲线,我们首先从 JPA 开始,简单介绍一个 JPA 示例:接着重构该示例,并引入 Sp ...

  5. [翻译] ALMoviePlayerController

    ALMoviePlayerController ALMoviePlayerController is a drop-in replacement for MPMoviePlayerController ...

  6. 心灵鸡汤[all]

    1. [iPhone 有哪些非常有必要下载的 App] 2. 相 信 自 己 3. 英语四级作文模板 4. 比尔盖茨的人生忠告 5. 李嘉诚 <Are you ready> 6. 李嘉诚语 ...

  7. 如何在C++中动态建立二维数组(转)

    http://blog.sina.com.cn/s/blog_7c073a8d0100qp1w.html http://blog.163.com/wujiaxing009@126/blog/stati ...

  8. My Heart Will Go On(我心永恒)

    My Heart Will Go On(我心永恒) 歌词(英文) 歌词(中文) 简介:电影<泰坦尼克号>插曲   歌手:Celine Dion(席琳·迪翁)   词作:韦尔·杰宁斯(Wil ...

  9. SQL Server之JSON 函数

    SQL Server 2005开始支持XML数据类型,提供原生的XML数据类型.XML索引及各种管理或输出XML格式的函数.随着JSON的流行,SQL Server2016开始支持JSON数据类型,不 ...

  10. vim高级操作命令

    1.首先在命令模式下,输入“:set nu”显示行号:通过行号确定你要删除的行:命令输入“:32,65d”,回车键,32-65行就被删除了,很快捷吧如果无意中删除错了,可以使用‘u’键恢复(命令模式下 ...