205315Java实验二实验报告

实验内容

  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.总结单元测试的好处
不容易遗漏细节上的设计,使问题考虑的更全面,可以使代码更友好。

posted @ 2016-04-14 13:06  君知らない  阅读(304)  评论(1编辑  收藏  举报