20155322 2016-2017-2 《Java面向对象程序设计》第十二周课堂练习之Arrays和String单元测试
20155322 2016-2017-2 《Java面向对象程序设计》第十二周课堂练习之Arrays和String单元测试
练习目地
在IDEA中以TDD的方式对String类和Arrays类进行学习
练习要求
- 测试相关方法的正常,错误和边界情况
- TDD的方式
- 在实验二ComplexTest的基础上进行修改
练习内容
- Strings类:
- charAt
- split
- Arrays类:
- sort
- binarySearch
练习过程:
1. charAt:
- 此方法返回位于字符串的指定索引处的字符。该字符串的索引从零开始。
- 该方法的返回指定索引处char值。
- 所以为了实现单元测试,我在
Complex.java
文件中添加如下代码:
//测试一
public static char String_charAt(String str, int i) {
return str.charAt(i);
}
//取测试一结果
public static char getString_charAt(String str, int i) {
return String_charAt(str, i);
}
在ComplexTest.java
中添加如下代码对其进行测试:
@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));
}
这里需要用到的包为:
import java.lang.*;
测试数组为:
String str = "dangranshixuanzeyuanliangtala";
最后测试结果如下:
2.split:
- 这个方法有两个变体,并分割这个字符串围绕给定的正则表达式匹配。
- 返回由分割这个字符串围绕给定的正则表达式匹配计算字符串数组。
- 为了实现单元测试,我在
Complex.java
文件中添加如下代码:
//测试二
public static String[] String_split(String str) {
String[] strsort = str.split(":");
return strsort;
}
//取测试二结果
public static String[] getString_split(String str) {
return String_split(str);
}
在ComplexTest.java
中添加如下代码对其进行测试:
@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]);
}
这里需要用到的包为:
import java.lang.*;
测试数组为:
String str2 = "dang:ran:shi:xuan:ze:yuan:liang:ta:la";
最后测试结果如下:
3. sort
- 我使用的sort为
java.util.Arrays.sort(char[])
, 方法字符指定数组排序按数字升序顺序。 - 此方法不返回任何值
- 为了实现单元测试,我在
Complex.java
文件中添加如下代码:
//测试三
public static String[] Arrays_sort(String[] str3) {
Arrays.sort(str3);
return str3;
}
//取测试三结果
public static String[] getArrays_sort(String[] str3) {
return Arrays_sort(str3);
}
在ComplexTest.java
中添加如下代码对其进行测试:
@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]);
}
这里需要用到的包为:
import java.util.Arrays;
测试数组为:
String[] str3 = new String[]{"dang", "ran", "shi", "xuan", "ze", "yuan", "liang", "ta", "la"};
最后测试结果如下:
4. binarySearch
- 方法搜索指定double数组,使用二进制搜索算法来指定值。该数组必须在进行此调用之前进行排序。如果不排序,则结果是不确定的。
- 此方法返回搜索键的索引,如果它包含在数组中,否则它返回(- (插入点)- 1)。插入点是在将键插入数组的那一点:第一个元素比键大,或如果阵列中的所有元素都小于指定的键的索引大于a.length。
- 为了实现单元测试,我在
Complex.java
文件中添加如下代码:
//测试四
public static double[] Arrays_binarySearch(double[] str4) {
Arrays.sort(str4);
return str4;
}
//取测试四结果
public static double[] getArrays_binarySearch(double[] str4) {
return Arrays_binarySearch(str4);
}
在ComplexTest.java
中添加如下代码对其进行测试:
@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));
}
这里需要用到的包为:
import java.util.Arrays;
测试数组为:
double str4[] = {5.4, 4.6, 49.2, 9.2, 35.4};
最后测试结果如下:
练习总结及git链接
练习收获:
通过这次课堂练习,使我进一步加深了对于TDD方式的理解和对使用assertEquals
掌握,并且学会了charAt
、split
、sort
、binarySearch
这些方法的使用,收获良多。
20155322 2016-2017-2 《Java面向对象程序设计》第十二周课堂练习之Arrays和String单元测试的更多相关文章
- 201871010123-吴丽丽《面向对象程序设计(Java)》第十二周学习总结
201871010123-吴丽丽<面向对象程序设计(Java)>第十二周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ ...
- 201271050130-滕江南-《面向对象程序设计(java)》第十二周学习总结
201271050130-滕江南-<面向对象程序设计(java)>第十二周学习总结 项 目 内 容 这个作业属于哪个课程 https://www.cnblogs.co ...
- 201871010111-刘佳华《面向对象程序设计(java)》第十二周学习总结
201871010111-刘佳华<面向对象程序设计(java)>第十二周学习总结 实验十 集合与GUI初步 实验时间 2019-11-14 第一部分:基础知识总结 第九章知识总结 1. ...
- 201871010109-胡欢欢《面向对象程序设计(java)》第十二周学习总结
201871010109-胡欢欢<面向对象程序设计(java)>第十二周学习总结 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这 ...
- 201871010101-陈来弟《面向对象程序设计(Java)》第十二周学习总结
201871010101-陈来弟<面向对象程序设计(Java)>第十二周学习总结 实验十 集合与GUI初步 实验时间 2019-11-14 第一部分 理论部分 1.(1) 用户界面 ...
- 201871010104-陈园园 《面向对象程序设计(java)》第十二周学习总结
201871010104-陈园园 <面向对象程序设计(java)>第十二周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ ...
- 201871010105-曹玉中《面向对象程序设计(java)》第十二周学习总结
201871010105-曹玉中<面向对象程序设计(java)>第十二周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ ...
- 201871010107-公海瑜《面向对象程序设计(java)》第十二周学习总结
201871010107-公海瑜<面向对象程序设计(java)>第十二周学习总结 项目 内容 ...
- 201871010133-赵永军《面向对象程序设计(java)》第十二周学习总结
201871010133-赵永军<面向对象程序设计(java)>第十二周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ ...
随机推荐
- vue组件详解(一)——组件与复用
一.什么是组件 组件 (Component) 是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码. 二.组件用法 组件需要注册后才可以使用,注册有全局注册和局部注册两种 ...
- 让IE6、7、8兼容@media属性
通常做页面适配的时候,经常会用到@media属性,对不同屏幕范围内的元素设置不同的样式.但是@media属性不兼容IE8及IE8以下的浏览器 解决方法: 直接在页面中引入respond.src.js即 ...
- lock与sychronized关键字
1. lock与sychronized关键字的区别 (1) Lock是一个接口,而synchronized是Java中的关键字,synchronized是内置的语言实现,Lock是代码层面的实现.(2 ...
- 远程执行newLISP代码
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/sheismylife/article/details/26393899 newLISP提供了一个简单 ...
- 「NOIP2018 保卫王国」
题目 强制选点我们可以把那个点权搞成\(-inf\),强制不选我们搞成\(inf\),之后就真的成为动态\(dp\)的板子题了 由于不想像板子那样再写一个最大独立集的方程,之后利用最小点覆盖=总点权- ...
- VIM在Win7上的安装教程
1.下载 目前VIM在其官网上的最新版本为7.4,Windows版本名称为GVIM,在百度软件中可以下载GVIM的最新版本,建议 在百度上下载,因为比较快.在百度上搜索"GVIM" ...
- [转]MVP+WCF+三层结构搭建项目框架
最近,我一直在重构之前做的一个项目,在这个过程中感慨万千.原先的项目是一个运用了WCF的C/S系统,在客户端运用了MVC模式,但MVC的View.Model耦合以及WCF端分布式欠佳等问题让我有了重构 ...
- HTML+JS实现视频上传显示进度条
示例代码: css部分: #content{border: 1px solid saddlebrown;padding: 16px;border-radius: 2px} .list {top: 15 ...
- GBK 文件在 sublime 保存时被强制保存为 utf-8 导致中文乱码, 恢复。
原来在 CoverteToUTF8 的 README.zh_CN.md 文件里就有解决方法,如下: * 问:我的文件被保存为 UTF-8,而且变成了乱码,要如何恢复? 答:请打开这个文件,并确认它的编 ...
- 模板——STL队列
C++ STL queue 容器优先队列&&队列 队列 #include<queue> #include<iostream> using namespace s ...