一、实验报告封面

课程:Java程序设计 班级:1752班 姓名:艾星言 学号:20175224

指导教师:娄嘉鹏 实验日期:2019年4月17日

实验时间:13:45 - 15:25 实验序号:24

实验名称:面向对象程序设计

实验内容

测试点一

  • “测试驱动开发”(TDD)。TDD的一般步骤如下:
  1. 明确当前要完成的功能,记录成一个测试列表
  2. 快速完成编写针对此功能的测试用例
  3. 测试代码编译不通过(没产品代码呢)
  4. 编写产品代码
  5. 测试通过
  6. 对代码进行重构,并保证测试通过(重构下次实验练习)
  7. 循环完成所有功能的开发

测试点二

  • 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原则
  1. SRP(Single ResponsibilityPrinciple,单一职责原则)
  2. OCP(Open-Closed Principle,开放-封闭原则)
  3. LSP(Liskov Substitusion Principle,Liskov替换原则)
  4. ISP(Interface Segregation Principle,接口分离原则)
  5. DIP(Dependency Inversion Principle,依赖倒置原则
  • 设计原则:
  1. OCP原则:开放-封闭yuanze。其具体内容为:软件实体扩充开放,修改关闭。可以通过抽象和继承;面对接口编程。
  2. DIP原则:依赖倒置原则。其具体内容为:高层模版不应该依赖与底层模版,二者都应该依赖于抽象;抽象不应该依赖于细节,细节一个依赖与抽象。
  • 设计模式有四个基本要素:
  1. Pattern name:描述模式,便于交流,存档
  2. Problem:描述何处应用该模式
  3. Solution:描述一个设计的组成元素,不针对特例
  4. 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开发思路回顾:
  1. 明确当前要完成的功能,记录成一个测试列表
  2. 快速完成编写针对此功能的测试用例
  3. 测试代码编译不通过(没产品代码呢)
  4. 编写产品代码
  5. 测试通过
  6. 对代码进行重构,并保证测试通过(重构下次实验练习)
  7. 循环完成所有功能的开发
  • 复数的四则运算公式
  1. (a+bi)+(c+di)=(a+c)+(b+d)i
  2. (a+bi)-(c+di)=(a-c)+(b-d)i
  3. (a+bi)*(c+di)=(ac-bd)+(ad+bc)i
  4. (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面向对象程序设计》实验报告的更多相关文章

  1. 20145213《Java程序设计》实验二Java面向对象程序设计实验报告

    20145213<Java程序设计>实验二Java面向对象程序设计实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装,继承,多态 初步掌握UML建模 熟悉S.O. ...

  2. 20145206《Java程序设计》实验二Java面向对象程序设计实验报告

    20145206<Java程序设计>实验二Java面向对象程序设计实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O. ...

  3. 20145308刘昊阳 《Java程序设计》实验二 Java面向对象程序设计 实验报告

    20145308刘昊阳 <Java程序设计>实验二 Java面向对象程序设计 实验报告 实验名称 Java面向对象程序设计 实验内容 初步掌握单元测试和TDD 理解并掌握面相对象三要素:封 ...

  4. 20162311 实验二 Java面向对象程序设计 实验报告

    实验二 Java面向对象程序设计 实验内容 1. 初步掌握单元测试和TDD 2. 理解并掌握面向对象三要素:封装.继承.多态 3. 初步掌握UML建模 4. 熟悉S.O.L.I.D原则 5. 了解设计 ...

  5. 实验二Java面向对象程序设计实验报告(2)

    实验二 Java面向对象程序设计 实验概述: 课程:程序设计与数据结构 班级:1623班 姓名: 邢天岳 学号:2309 指导老师:娄老师 王老师 实验日期:2017.4.16 实验名称: Java面 ...

  6. 实验二 Java面向对象程序设计实验报告

    实验二 Java面向对象程序设计 实验内容 1.初步掌握单元测试和TDD 2.理解并掌握面向对象三要素:封装.继承.多态 3.初步掌握UML建模 4.熟悉S.O.L.I.D原则 5.了解设计模式 实验 ...

  7. 20145326《Java程序设计》实验二Java面向对象程序设计实验报告

    20145326<Java程序设计>实验二Java面向对象程序设计实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O. ...

  8. 20155217 实验二 Java面向对象程序设计 实验报告

    20155217 实验二 Java面向对象程序设计 实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 了解设计模 ...

  9. 20145219 《Java程序设计》实验二 Java面向对象程序设计实验报告

    20145219 <Java程序设计>实验二 Java面向对象程序设计实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S. ...

  10. 20162305 实验二 Java面向对象程序设计 实验报告

    20162305 实验二 Java面向对象程序设计 实验报告 实验内容 1.初步掌握单元测试和TDD 2.理解并掌握面向对象三要素:封装.继承.多态 3.初步掌握UML建模 4.熟悉S.O.L.I.D ...

随机推荐

  1. 算法 set / multiset -- lower_bound()的二分搜索

    lower_bound() 在数组中搜索时 搜不到 返回 .end(), 若需要返回0,用upper_bound()-lower_bound() 若要返回下一个下标  则需要在set / multis ...

  2. postgres 11 单实例最大支持多少个database?

    有人在pg8时代(10年前)问过,当时说10000个没问题,而且每个db会在/base下建立1个文件夹, 文件ext3只支持32000个子文件夹,所以这是上限了. 而现在早就ext4了,根本没有限制了 ...

  3. MySQL 存储过程错误处理

    MySQL  存储过程错误处理 如何使用MySQL处理程序来处理在存储过程中遇到的异常或错误. 当存储过程中发生错误时,重要的是适当处理它,例如:继续或退出当前代码块的执行,并发出有意义的错误消息. ...

  4. vi编程技巧:

    h #向上j #向左k #向右l #向下a #插入o #插入一行,并在行首开始O #在当前行前插入一行,并在行首开始dd #删除当前行x #删除当前字符yy #复制当前行p #在当前行后面粘贴P #在 ...

  5. 异常: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,意思 ...

  6. random froest 调参

    https://blog.csdn.net/wf592523813/article/details/86382037 https://blog.csdn.net/xiayto/article/deta ...

  7. 李航《统计学习方法》CH02

    CH02 感知机 前言 章节目录 感知机模型 感知机学习策略 数据集的线性可分性 感知机学习策略 感知机学习算法 感知机学习算法 感知机学习算法的原始形式 算法的收敛性 感知机学习算法的对偶形式 导读 ...

  8. react 的基础

    首先下载React 的安装包,可以到官网下载.也可以使用React Demos 已经自带 React 源码,不用另外安装,只需把这个库拷贝到硬盘中使用. (可参考http://www.ruanyife ...

  9. so so.*.*

    转自:http://unix.stackexchange.com/questions/5719/linux-gnu-gcc-ld-version-scripts-and-the-elf-binary- ...

  10. Oracle Database 11g安装及报错处理(win7)

    稍后会将安装过程上传.Oracle数据库安装先决条件检查失败解决方案: 1,检查失败信息中,预期值:N/A  实际值:N/A ,并未出现具体的值  查看  “详细信息” . 引起失败的原因是:无法在指 ...