2018-2019-2 20175224 实验二《Java面向对象程序设计》实验报告
一、实验报告封面
课程:Java程序设计 班级:1752班 姓名:艾星言 学号:20175224
指导教师:娄嘉鹏 实验日期:2019年4月17日
实验时间:13:45 - 15:25 实验序号:24
实验名称:面向对象程序设计
实验内容
测试点一
- “测试驱动开发”(TDD)。TDD的一般步骤如下:
- 明确当前要完成的功能,记录成一个测试列表
- 快速完成编写针对此功能的测试用例
- 测试代码编译不通过(没产品代码呢)
- 编写产品代码
- 测试通过
- 对代码进行重构,并保证测试通过(重构下次实验练习)
- 循环完成所有功能的开发
测试点二
public int capacity()
返回当前容量。容量指可用于最新插入字符的存储量,超过这一容量便需要再次分配。- 示例代码如下,使用TDD学习测试四个方法。
public class StringBufferDemo {
public static void main(String [] args) {
StringBuffer buffer = new StringBuffer();
buffer.append('S');//调用方法append,输入char型
buffer.append("tringBuffer");//调用方法append,输入String型
System.out.println(buffer.charAt(1));//t
System.out.println(buffer.capacity());//返回buffer对象的容量:16
System.out.println(buffer.length());//返回buffer对象的长度:12
System.out.println(buffer.indexOf("tring"));//返回输入的子字符串的第一个字母在母字符串的位置。
System.out.println("buffer = " + buffer.toString());
}
}
- 测试代码为:
import junit.framework.TestCase;
import org.testng.annotations.Test;
public class StringBufferDemoTest extends TestCase {
StringBuffer a= new StringBuffer("String");
StringBuffer b = new StringBuffer("StringBuffer");
@Test
public void testcharAt() throws Exception{
assertEquals('S',a.charAt(0));
assertEquals('g',a.charAt(5));
}
@Test
public void testcapacity() throws Exception{
assertEquals(22,a.capacity());
assertEquals(28,b.capacity());
}
@Test
public void testlength() throws Exception{
assertEquals(6,a.length());
assertEquals(12,b.length());
}
@Test
public void testindexOf() throws Exception{
assertEquals(0,a.indexOf("Str"));
assertEquals(6,b.indexOf("Bu"));
}
}
测试点三
设计模式初步
- S.O.L.I.D原则
- SRP(Single ResponsibilityPrinciple,单一职责原则)
- OCP(Open-Closed Principle,开放-封闭原则)
- LSP(Liskov Substitusion Principle,Liskov替换原则)
- ISP(Interface Segregation Principle,接口分离原则)
- DIP(Dependency Inversion Principle,依赖倒置原则
- 设计原则:
- OCP原则:开放-封闭yuanze。其具体内容为:软件实体扩充开放,修改关闭。可以通过抽象和继承;面对接口编程。
- DIP原则:依赖倒置原则。其具体内容为:高层模版不应该依赖与底层模版,二者都应该依赖于抽象;抽象不应该依赖于细节,细节一个依赖与抽象。
- 设计模式有四个基本要素:
- Pattern name:描述模式,便于交流,存档
- Problem:描述何处应用该模式
- Solution:描述一个设计的组成元素,不针对特例
- Consequence:应用该模式的结果和权衡(trade-offs)
// Server Classes
abstract class Data {//抽象一个类
abstract public void DisplayValue();//抽象方法,无返回。
}
class Integer extends Data {//继承抽象类,重写方法
int value;
Integer() {
value=100;
}
public void DisplayValue(){
System.out.println (value);
}
}
class byteteger extends Data {
byte value;
byteteger() {
value=24;
}
public void DisplayValue() {
System.out.println(value);
}
}
// Pattern Classes
abstract class Factory {//抽象一个类
abstract public Data CreateDataObject();//抽象方法,返回一个Date类创建的对象
}
class IntFactory extends Factory {//继承抽象类,重写方法
public Data CreateDataObject(){//返回一个Integer类创建的对象
return new Integer();
}
}
class byteFactoey extends Factory {
public Data CreateDataObject() {
return new byteteger();
}
}
//Client classes
class Document {
Data pd;
Document(Factory pf){
pd = pf.CreateDataObject();
}
public void DisplayData(){
pd.DisplayValue();
}
}
//Test class
public class MyDoc {
static Document d;
static Document b;
public static void main(String[] args) {
d = new Document(new IntFactory());
d.DisplayData();
b=new Document(new byteFactoey());
b.DisplayData();
}
}
测试点四
- 提交:单元测试代码和运行成功截图及码云上代码链接,截图要加上学号水印
- 任务:以TDD的方式开发一个复数类Complex,要求如下:
// 定义属性并生成getter,setter
double RealPart;
double ImagePart;
// 定义构造函数
public Complex()
public Complex(double R,double I) //Override Object
public boolean equals(Object obj)
public String toString() // 定义公有方法:加减乘除
Complex ComplexAdd(Complex a)
Complex ComplexSub(Complex a)
Complex ComplexMulti(Complex a)
Complex ComplexDiv(Complex a)
- TDD开发思路回顾:
- 明确当前要完成的功能,记录成一个测试列表
- 快速完成编写针对此功能的测试用例
- 测试代码编译不通过(没产品代码呢)
- 编写产品代码
- 测试通过
- 对代码进行重构,并保证测试通过(重构下次实验练习)
- 循环完成所有功能的开发
- 复数的四则运算公式
- (a+bi)+(c+di)=(a+c)+(b+d)i
- (a+bi)-(c+di)=(a-c)+(b-d)i
- (a+bi)*(c+di)=(ac-bd)+(ad+bc)i
- (a+bi)/(c+di)=(a+bi)(c-di)/(c^2+d^2)
按照步骤:
- 测试代码为:
/*(1)属性:复数包含实部和虚部两个部分,
double RealPart;复数的实部
double ImagePart;复数的虚部
getRealPart():返回复数的实部
getImagePart();返回复数的虚部
setRealPart():设置复数的实部
setImagePart();设置复数的虚部
输出形式:a+bi
(2)方法:
①定义构造函数
public Complex()
public Complex(double R,double I)
②定义公有方法:加减乘除
Complex ComplexAdd(Complex a):实现复数加法
Complex ComplexSub(Complex a):实现复数减法
Complex ComplexMulti(Complex a):实现复数乘法
Complex ComplexDiv(Complex a):实现复数除法
③Override Object
public String toString():将计算结果转化为字符串形式并输出*/ import junit.framework.TestCase;
import org.testng.annotations.Test;
public class ComplexTest extends TestCase {
Complex c1=new Complex(1,1);
Complex c2=new Complex(1,0);
Complex c3=new Complex(0,1);
Complex c4=new Complex(-1,-1);
@Test
public void testComplexAdd() {
assertEquals("2.0+1.0i",c1.ComplexAdd(c2).toString());
assertEquals("1.0+1.0i",c2.ComplexAdd(c3).toString());
assertEquals("1.0+1.0i",c3.ComplexAdd(c2).toString());
assertEquals("0.0",c1.ComplexAdd(c4).toString());
}
@Test
public void testComplexSub() {
assertEquals("1.0i",c1.ComplexSub(c2).toString());
assertEquals("1.0",c1.ComplexSub(c3).toString());
assertEquals("2.0+2.0i",c1.ComplexSub(c4).toString());
assertEquals("1.0-1.0i",c2.ComplexSub(c3).toString());
}
@Test
public void testComplexMulti() {
assertEquals("1.0+1.0i",c1.ComplexMulti(c2).toString());
assertEquals("-1.0+1.0i",c1.ComplexMulti(c3).toString());
assertEquals("1.0i",c2.ComplexMulti(c3).toString());
assertEquals("-2.0i",c1.ComplexMulti(c4).toString());
}
@Test
public void testComplexDiv() {
assertEquals("1.0+1.0i", c1.ComplexDiv(c2).toString());
assertEquals("1.0+1.0i", c1.ComplexDiv(c3).toString());
assertEquals("-1.0-1.0i", c1.ComplexDiv(c4).toString());
assertEquals("-0.5-0.5i", c2.ComplexDiv(c4).toString());
}
}
- 产品代码为:
/*(1)属性:复数包含实部和虚部两个部分,
double RealPart;复数的实部
double ImagePart;复数的虚部
getRealPart():返回复数的实部
getImagePart();返回复数的虚部
setRealPart():设置复数的实部
setImagePart();设置复数的虚部
输出形式:a+bi
(2)方法:
①定义构造函数
public Complex()
public Complex(double R,double I)
②定义公有方法:加减乘除
Complex ComplexAdd(Complex a):实现复数加法
Complex ComplexSub(Complex a):实现复数减法
Complex ComplexMulti(Complex a):实现复数乘法
Complex ComplexDiv(Complex a):实现复数除法
③Override Object
public String toString():将计算结果转化为字符串形式并输出
*/
public class Complex {
private double RealPart;//复数的实部
private double ImagePart;//复数的虚部
public Complex() {}
public Complex(double a, double b) {
setRealPart(a);
setImagePart(b);
}
public void setRealPart(double a) {
RealPart = a;
}
public void setImagePart(double b) {
ImagePart = b;
}
public double getRealPart() {//返回复数的实部
return RealPart;
}
public double getImagePart() {
return ImagePart;
}
Complex ComplexAdd(Complex a) {//(a+bi)+(c+di)=(a+c)+(b+d)i
Complex complex = new Complex();
complex.RealPart = this.RealPart + a.RealPart;
complex.ImagePart = this.ImagePart + a.ImagePart;
return complex;
}
Complex ComplexSub(Complex a) {//(a+bi)-(c+di)=(a-c)+(b-d)i
Complex complex=new Complex();
complex.RealPart=this.RealPart-a.RealPart;
complex.ImagePart=this.ImagePart-a.ImagePart;
return complex;
}
Complex ComplexMulti(Complex a) {//(a+bi)*(c+di)=(ac-bd)+(ad+bc)i
Complex complex =new Complex();
complex.RealPart=this.RealPart*a.RealPart-this.ImagePart*a.ImagePart;
complex.ImagePart=this.RealPart*a.ImagePart+this.ImagePart*a.RealPart;
return complex;
}
Complex ComplexDiv(Complex a) {//(a+bi)/(c+di)=(a+bi)(c-di)/(c^2+d^2)
Complex complex=new Complex();
complex.RealPart=(this.RealPart*a.ImagePart+this.ImagePart*a.RealPart)/(a.ImagePart*a.ImagePart+a.RealPart*a.RealPart);
complex.ImagePart=(this.ImagePart*a.ImagePart+this.RealPart*a.RealPart)/(a.ImagePart*a.ImagePart+a.RealPart*a.RealPart);
return complex;
}
public String toString() {
if (ImagePart==0) {
String str = String.valueOf(RealPart);
return str;
}
else if (RealPart==0) {
String str = String.valueOf(ImagePart)+"i";
return str;
}
else {
if (ImagePart>0) {
String str = String.valueOf(RealPart) + "+" + String.valueOf(ImagePart) + "i";
return str;
}
else {
String str = String.valueOf(RealPart) + String.valueOf(ImagePart) + "i";
return str;
}
}
}
}
- 测试结果:
测试点五
- 检查点要求:使用WhiteStarUML对实验二中的代码进行建模,发类图的截图,加上学号水印。参考http://www.cnblogs.com/rocedu/p/6736847.html
- 类图中只少两个类。
实验中遇到的问题
1.增加MyUtil
的测试类之后,TestCase
是红色的,但是没有找到junit.jar
包的地方
解决方法:
- 找到电脑中IDEA安装路径
- 打开File->Project Structure
- 点击
Dependencies
,单击右上角的+,然后选择第一个JARs or directories
- 复制刚才的路径名,找到
junit-4.12 jar
、junit.jar
- 选择
junit-4.12 jar
、junit.jar
两项,并点击下方Ok
2.对于变量的使用,最开始没注意使用this关键字,运算出错。
解决方法:
- P84在实例方法中使用this:当this关键字出现在实例方法中时,this就代表正在调用该方法的当前对象
PSP
步骤 | 耗时 | 百分比 |
---|---|---|
需求分析 | 10min | 6% |
设计 | 20min | 11% |
代码实现 | 60min | 35% |
测试 | 30min | 18% |
分析总结 | 50min | 30% |
2018-2019-2 20175224 实验二《Java面向对象程序设计》实验报告的更多相关文章
- 20145213《Java程序设计》实验二Java面向对象程序设计实验报告
20145213<Java程序设计>实验二Java面向对象程序设计实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装,继承,多态 初步掌握UML建模 熟悉S.O. ...
- 20145206《Java程序设计》实验二Java面向对象程序设计实验报告
20145206<Java程序设计>实验二Java面向对象程序设计实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O. ...
- 20145308刘昊阳 《Java程序设计》实验二 Java面向对象程序设计 实验报告
20145308刘昊阳 <Java程序设计>实验二 Java面向对象程序设计 实验报告 实验名称 Java面向对象程序设计 实验内容 初步掌握单元测试和TDD 理解并掌握面相对象三要素:封 ...
- 20162311 实验二 Java面向对象程序设计 实验报告
实验二 Java面向对象程序设计 实验内容 1. 初步掌握单元测试和TDD 2. 理解并掌握面向对象三要素:封装.继承.多态 3. 初步掌握UML建模 4. 熟悉S.O.L.I.D原则 5. 了解设计 ...
- 实验二Java面向对象程序设计实验报告(2)
实验二 Java面向对象程序设计 实验概述: 课程:程序设计与数据结构 班级:1623班 姓名: 邢天岳 学号:2309 指导老师:娄老师 王老师 实验日期:2017.4.16 实验名称: Java面 ...
- 实验二 Java面向对象程序设计实验报告
实验二 Java面向对象程序设计 实验内容 1.初步掌握单元测试和TDD 2.理解并掌握面向对象三要素:封装.继承.多态 3.初步掌握UML建模 4.熟悉S.O.L.I.D原则 5.了解设计模式 实验 ...
- 20145326《Java程序设计》实验二Java面向对象程序设计实验报告
20145326<Java程序设计>实验二Java面向对象程序设计实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O. ...
- 20155217 实验二 Java面向对象程序设计 实验报告
20155217 实验二 Java面向对象程序设计 实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 了解设计模 ...
- 20145219 《Java程序设计》实验二 Java面向对象程序设计实验报告
20145219 <Java程序设计>实验二 Java面向对象程序设计实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S. ...
- 20162305 实验二 Java面向对象程序设计 实验报告
20162305 实验二 Java面向对象程序设计 实验报告 实验内容 1.初步掌握单元测试和TDD 2.理解并掌握面向对象三要素:封装.继承.多态 3.初步掌握UML建模 4.熟悉S.O.L.I.D ...
随机推荐
- 算法 set / multiset -- lower_bound()的二分搜索
lower_bound() 在数组中搜索时 搜不到 返回 .end(), 若需要返回0,用upper_bound()-lower_bound() 若要返回下一个下标 则需要在set / multis ...
- postgres 11 单实例最大支持多少个database?
有人在pg8时代(10年前)问过,当时说10000个没问题,而且每个db会在/base下建立1个文件夹, 文件ext3只支持32000个子文件夹,所以这是上限了. 而现在早就ext4了,根本没有限制了 ...
- MySQL 存储过程错误处理
MySQL 存储过程错误处理 如何使用MySQL处理程序来处理在存储过程中遇到的异常或错误. 当存储过程中发生错误时,重要的是适当处理它,例如:继续或退出当前代码块的执行,并发出有意义的错误消息. ...
- vi编程技巧:
h #向上j #向左k #向右l #向下a #插入o #插入一行,并在行首开始O #在当前行前插入一行,并在行首开始dd #删除当前行x #删除当前字符yy #复制当前行p #在当前行后面粘贴P #在 ...
- 异常:Error resolving template "xxx", template might not exist or might not be accessible...解决办法
在开发环境下正常,但使用jar运行时,报错Error resolving template template might not exist or might not be accessible,意思 ...
- random froest 调参
https://blog.csdn.net/wf592523813/article/details/86382037 https://blog.csdn.net/xiayto/article/deta ...
- 李航《统计学习方法》CH02
CH02 感知机 前言 章节目录 感知机模型 感知机学习策略 数据集的线性可分性 感知机学习策略 感知机学习算法 感知机学习算法 感知机学习算法的原始形式 算法的收敛性 感知机学习算法的对偶形式 导读 ...
- react 的基础
首先下载React 的安装包,可以到官网下载.也可以使用React Demos 已经自带 React 源码,不用另外安装,只需把这个库拷贝到硬盘中使用. (可参考http://www.ruanyife ...
- so so.*.*
转自:http://unix.stackexchange.com/questions/5719/linux-gnu-gcc-ld-version-scripts-and-the-elf-binary- ...
- Oracle Database 11g安装及报错处理(win7)
稍后会将安装过程上传.Oracle数据库安装先决条件检查失败解决方案: 1,检查失败信息中,预期值:N/A 实际值:N/A ,并未出现具体的值 查看 “详细信息” . 引起失败的原因是:无法在指 ...