实验内容

  1. 初步掌握单元测试和TDD

  2. 理解并掌握面向对象三要素:封装、继承、多态

  3. 初步掌握UML建模

  4. 熟悉S.O.L.I.D原则

  5. 了解设计模式

实验步骤

(一)单元测试

用程序解决问题时,要会写三种码:

1.先按要求写出伪代码。

2.然后写出产品代码。

3.最后进行测试。

(二) TDD(Test Driven Devlopment, 测试驱动开发)

先根据需求写测试代码,然后再根据测试写产品代码,使产品代码通过测试。

1.先创建一个test文件夹,修改其属性用来存放测试代码。

2.在src中新建.java文件,用来编写产品代码。

3.创建产品代码中的测试类,并存放到测试文件夹text中。

4.根据需求编写测试代码。

试验测试代码:

输入测试代码:

5.因为没有产品代码,测试代码存在错误,接下来,输入产品代码。

此时,测试代码运行成功

(三)用UML中的类图来描述类

这个实验我是在实验楼上做的:

(四)练习

使用TDD的方式设计关实现复数类Complex。

1.PSP(Personal Software Process)

步骤 耗时 百分比
需求分析 20分钟 7.7%
设计 60分钟 23%
代码实现 120分钟 46%
测试 40分钟 15%
分析总结 20分钟 7.7%
  1. 实现要有伪代码,产品代码,测试代码。

伪代码:

ComplexNumber() 构造函数,将实部,虚部都置为0

ComplexNumber(double r, double I) 构造函数,创建复数对象的同时完成复数的实部,虚部的初始化

GetRealPart() 获取实部

GetImaginaryPart() 获取虚部

SetRealPart(double d) 设置实部

SetImaginaryPart(double d) 设置虚部

ComplexAdd(ComplexNumber c) 复数相加

ComplexAdd(double c) 复数相加

ComplexMinus(ComplexNumber c) 复数相减

ComplexMinus(double c) 复数相减

ComplexMulti(ComplexNumber c)  复数相乘

ComplexMulti(double c)  复数相乘

实现复数运算:

创建复数对象a,b,c.

设置a,b的实部和虚部。

分别计算:

c=a+b;

c=a-b;

c=a*b;

产品代码:

class Complex {
private double m_dRealPart;//实部
private double m_dImaginPart;//虚部
Complex(double m_dRealPart,double m_dImaginPart){
this.m_dImaginPart=m_dImaginPart;
this.m_dRealPart=m_dRealPart;
}
public void ComplexNumber(){//将实部,虚部都置为0
this.m_dImaginPart=0;
this.m_dRealPart=0; }
public void ComplexNumber(double R, double I){//构造函数,创建复数对象的同时完成复数的实部,虚部的初始化
this.m_dRealPart=R;
this.m_dImaginPart=I;
}
public double GetRealPart(){//获取实部 return this.m_dRealPart;
}
public double GetImaginaryPart(){//获取虚部 return this.m_dImaginPart;
}
public void SetRealPart(double d){//设置实部
this.m_dRealPart=d; }
public void SetImaginaryPart(double d){//设置虚部
this.m_dImaginPart=d;
}
public void ComplexAdd(Complex a,Complex b){//加法 this.m_dRealPart=a.GetRealPart()+b.GetRealPart();
this.m_dImaginPart=a.GetImaginaryPart()+b.GetImaginaryPart(); System.out.printf("a+b=%.2f+%.2fi%n",this.m_dRealPart,this.m_dImaginPart); }
public void ComplexMinus(Complex a,Complex b){//减法 this.m_dRealPart=a.GetRealPart()-b.GetRealPart();
this.m_dImaginPart=a.GetImaginaryPart()-b.GetImaginaryPart();
System.out.printf("a-b=(%.2f)+(%.2fi)%n",this.m_dRealPart,this.m_dImaginPart); }
public void CComplexMulti(Complex a,Complex b){ //乘法 this.m_dRealPart=a.m_dRealPart*b.m_dRealPart-a.m_dImaginPart*b.m_dImaginPart;
this.m_dImaginPart=a.m_dImaginPart*b.m_dRealPart+a.m_dRealPart*b.m_dImaginPart;
System.out.printf("a*b=%.2f+%.2fi%n",this.m_dRealPart,this.m_dImaginPart); } } public class ComplexCount {
public static void main(String[] args) { Scanner scanner=new Scanner(System.in);
Complex a=new Complex(0,0); //建立实例
Complex b=new Complex(0,0);
Complex c=new Complex(0,0);
System.out.println("请输入a的实部和虚部");
double r1=scanner.nextDouble();
double i1=scanner.nextDouble();
System.out.println("请输入b的实部和虚部");
double r2=scanner.nextDouble(); //输入实部和虚部
double i2=scanner.nextDouble();
a.SetRealPart(r1 );
a.SetImaginaryPart(i1);
b.SetRealPart(r2);
b.SetImaginaryPart(i2);
c. ComplexAdd(a,b); //加法
c. ComplexMinus(a,b); //减法
c. CComplexMulti(a,b); //乘法
}
}

运行结果:

测试代码:

public class test {
public static void main(String[] args) {
Complex testa = new Complex(1, 2);
Complex testb = new Complex(3, 5);
Complex testc = new Complex(0, 0);
testc.ComplexAdd(testa,testb);
if(testc.GetRealPart()==4&&testc.GetImaginaryPart()==7)
System.out.println("test passed!");
else
System.out.println("test failed!"); }
}

测试结果:

4.总结单元测试的好处

不容易遗漏细节上的设计,使问题考虑的更全面,可以使代码更友好。

205315Java实验二实验报告的更多相关文章

  1. 20145120 《Java程序设计》实验二实验报告

    20145120 <Java程序设计>实验二实验报告 实验名称:Java面向对象程序设计 实验目的与要求: 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握U ...

  2. 2015526 《Java程序设计》实验二实验报告

    2015526 <Java程序设计>实验二实验报告 一.单元测试和TDD 用程序解决问题时,要学会写以下三种代码: 伪代码 产品代码 测试代码 正确的顺序应为:伪代码(思路)→ 测试代码( ...

  3. 20155301 《Java程序设计》实验二实验报告

    20155301 <Java程序设计>实验二实验报告 一.单元测试和TDD 用程序解决问题时,要学会写以下三种代码: 伪代码 产品代码 测试代码 正确的顺序应为:伪代码(思路)→ 测试代码 ...

  4. 20145314郑凯杰 《Java程序设计》实验二 实验报告

    20145314郑凯杰 <Java程序设计>实验二 实验报告 实验要求 完成实验.撰写实验报告,实验报告以博客方式发表在博客园,注意实验报告重点是运行结果,遇到的问题(工具查找,安装,使用 ...

  5. 20145328 《Java程序设计》实验二实验报告

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

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

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

  7. 20155235 《Java程序设计》 实验二 实验三 敏捷开发与XP实践

    20155235 <Java程序设计> 实验二 实验三 敏捷开发与XP实践 实验内容 XP基础 XP核心实践 相关工具 实验内容 没有Linux基础的同学建议先学习<Linux基础入 ...

  8. 实验二实验报告 20135324&&20135330

    北京电子科技学院(BESTI) 实 验 报 告 课程: 深入理解计算机系统 班级: 1353 姓名: 杨舒雯 张若嘉 学号: 20135324 20135330 成绩: 指导教师: 娄嘉鹏 实验日期: ...

  9. 《Java程序设计》实验二 实验报告

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

随机推荐

  1. linux 个性化设置shell提示

    1.linux 用户登录过程中 相关文件执行顺序: /etc/profile → /etc/profile.d/*.sh → ~/.bash_profile → ~/.bashrc → [/etc/b ...

  2. Android开发 Android Studio2.0 教程从入门到精通Windows版 - 入门篇

    第一篇 介绍了Android Studio开发环境以及Genymotion虚拟机安装方法,本节将给大家介绍如何使用Android Studio开发应用. 开发第一应用 可以开发属于自己的应用,是否有点 ...

  3. MQTT的学习研究(十五) MQTT 和android整合文章

    详细参考:  How to Implement Push Notifications for Android http://tokudu.com/2010/how-to-implement-push- ...

  4. Docker 使用指南 (五)—— Dockerfile 详解

    版权声明:本文由田飞雨原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/97 来源:腾云阁 https://www.qclou ...

  5. 几种减小javascript对性能影响的方法

    1.将所有的script标签放在页面的底部,body的结束标签</body>之前. 2.将脚本打包,script标签越少,请求数就越少,加载速度加快,相应的响应时间变短. 3.使用非阻塞的 ...

  6. CRUX下实现进程隐藏(3)

    通过一个内核模块拦截文件系统的回调函数来实现进程隐藏. VFS(Virtual File System)是Linux在实际文件系统(如ext3,ext4,vfat等)上抽象出的一个文件系统模型,简单来 ...

  7. CentOS下PostgreSQL的安装与配置

    一.CentOS下PostgreSQL的yum安装: #安装yum源,默认源存在对版本的支持不好,下载不到等等问题. yum install http://yum.postgresql.org/9.5 ...

  8. Oracle卸载之正确卸载rac数据库的方法(MOS卸载方法)

    一.关闭数据库和资源 1.节点1 [root@node1 bin]# pwd /u01/app/11.2.0/grid/bin [root@node1 bin]# ./crsctl stop crs ...

  9. F(N)---hdu2802(寻找循环节)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2802 f[1] = 1; f[2] = 7; f[n] = (f[n-2] - (n-1)*(n-1) ...

  10. Monkey Tradition---LightOj1319(中国剩余定理模板)

    题目链接:http://lightoj.com/volume_showproblem.php?problem=1319 题意:有 n 个猴子,n 棵树,树的高度为 L ,每个猴子刚开始的时候都在树的底 ...