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

实验内容

  • 初步掌握单元测试和TDD
  • 理解并掌握面向对象三要素:封装、继承、多态
  • 初步掌握UML建模
  • 熟悉S.O.L.I.D原则
  • 了解设计模式

实验步骤

  • 单元测试

1.三种代码:伪代码、产品代码、测试代码。我们应该先写伪代码->再用特定编程语言翻译成产品代码->最后写测试代码,验证自己的代码有没有问题。

(1)伪代码

百分制转五分制:
如果成绩小于60,转成“不及格”
如果成绩在60与70之间,转成“及格”
如果成绩在70与80之间,转成“中等”
如果成绩在80与90之间,转成“良好”
如果成绩在90与100之间,转成“优秀”
其他,转成“错误”

(2)产品代码

public class MyUtil{
public static String percentage2fivegrade(int grade){
//如果成绩小于60,转成“不及格”
if (grade < 60)
return "不及格";
//如果成绩在60与70之间,转成“及格”
else if (grade < 70)
return "及格";
//如果成绩在70与80之间,转成“中等”
else if (grade < 80)
return "中等";
//如果成绩在80与90之间,转成“良好”
else if (grade < 90)
return "良好";
//如果成绩在90与100之间,转成“优秀”
else if (grade < 100)
return "优秀";
//其他,转成“错误”
else
return "错误";
}
}

(3)测试代码

用50分测试时:

public class MyUtilTest {
public static void main(String[] args) {
// 百分制成绩是50时应该返回五级制的“不及格”
if(MyUtil.percentage2fivegrade(50) != "不及格")
System.out.println("test failed!");
else
System.out.println("test passed!");
}
}

增加对负分的判断后:

public class MyUtil3{
public static String percentage2fivegrade(int grade){
//如果成绩小于0,转成“错误”
if ((grade < 0))
return "错误";
//如果成绩小于60,转成“不及格”
else if (grade < 60)
return "不及格";
//如果成绩在60与70之间,转成“及格”
else if (grade < 70)
return "及格";
//如果成绩在70与80之间,转成“中等”
else if (grade < 80)
return "中等";
//如果成绩在80与90之间,转成“良好”
else if (grade < 90)
return "良好";
//如果成绩在90与100之间,转成“优秀”
else if (grade <= 100)
return "优秀";
//如果成绩大于100,转成“错误”
else
return "错误";
}
}

测试边界情况:

public class MyUtilTest4{
public static void main(String[] args) {
//测试边界情况
if(MyUtil2.percentage2fivegrade(0) != "不及格")
System.out.println("test failed 1!");
else if(MyUtil2.percentage2fivegrade(60) != "及格")
System.out.println("test failed 2!");
else if(MyUtil2.percentage2fivegrade(70) != "中等")
System.out.println("test failed 3!");
else if(MyUtil2.percentage2fivegrade(80) != "良好")
System.out.println("test failed 4!");
else if(MyUtil2.percentage2fivegrade(90) != "优秀")
System.out.println("test failed 5!");
else if(MyUtil3.percentage2fivegrade(100) != "优秀")
System.out.println("test failed 6!");
else
System.out.println("test passed!");
}
}

TDD

  • 先写测试代码,然后再写产品代码的开发方法叫“测试驱动开发”(TDD)。
  • TDD的一般步骤如下:

    1、明确当前要完成的功能,记录成一个测试列表

    2、快速完成编写针对此功能的测试用例

    3、测试代码编译不通过(没产品代码呢)

    4、编写产品代码

    5、测试通过

    6、对代码进行重构,并保证测试通过(重构下次实验练习)

面向对象三要素

  • 面向对象(Object-Oriented)的三要素包括:封装、继承、多态。
  • 面向对象的思想涉及到软件开发的各个方面,如面向对象分析(OOA)、面向对象设计(OOD)、面向对象编程实现(OOP)。
  • OOA根据抽象关键的问题域来分解系统,关注是什么(what)。
  • OOD是一种提供符号设计系统的面向对象的实现过程,用非常接近问题域术语的方法把系统构造成“现实世界”的对象,关注怎么做(how),通过模型来实现功能规范。
  • OOP则在设计的基础上用编程语言(如Java)编码。贯穿OOA、OOD和OOP的主线正是抽象。
public class Dog {
private String color;
public String getColor() {
return color;
}
public void setColor(String color) {
this.color = color;
}
public String bark(){
return "汪汪";
}
public String toString(){
return "The Dog's color is " + this.getColor() +", and it shouts "+ this.bark() + "!";
}
}

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

  • SRP(Single Responsibility Principle,单一职责原则)
  • OCP(Open-Closed Principle,开放-封闭原则)
  • LSP(Liskov Substitusion Principle,Liskov替换原则)
  • ISP(Interface Segregation Principle,接口分离原则)
  • DIP(Dependency Inversion Principle,依赖倒置原则)

初步掌握UML建模

我们可以用UML中的类图来描述类Dog,首先我们在实验楼的环境中打开shell,在命令行中输入umbrello,打开UML建模软件umbrello

练习

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

  • 伪代码

    复数类Complex
    
    复数=实部数+虚部数 i
    
    复数相加 = (实部+实部) + (虚部 + 虚部)i
    
    复数相减 = (实部-实部) + (虚部 - 虚部)i
    
    打印复数:
    
    虚部大于0  "实部"+"+"+"虚部"+"i"
    
    虚部小于0  "实部"+"虚部"+"i"
    
    虚部为0     "实部"
  • 产品代码

    publicclassComplexNumber
    {
    double r,i; public ComplexNumber(){
    this.r=0;
    this.i=0;
    }
    public ComplexNumber(double r, double i){
    this.r=r;
    this.i=i;
    }
    public double GetRealPart(){
    returnthis.r;
    }
    public double GetImaginaryPart(){
    returnthis.i;
    }
    public void SetRealPart(double r){
    this.r=r;
    }
    public void SetImaginaryPart(double i){
    this.i=i;
    }
    public ComplexNumber ComplexAdd(ComplexNumber a,ComplexNumber b)
    {
    ComplexNumber temp = new ComplexNumber();
    temp.r = a.r + b.r;
    temp.i = a.i + b.i;
    return temp;
    }
    public ComplexNumber ComplexMinus(ComplexNumber a,ComplexNumber b)
    {
    ComplexNumber temp =new ComplexNumber();
    temp.r=a.r - b.r;
    temp.i =a.i - b.i;
    return temp;
    }
    public ComplexNumber ComplexMulti(ComplexNumber a,ComplexNumber b)
    {
    ComplexNumber temp = new ComplexNumber();
    temp.r = a.r*b.r-a.i*b.i;
    temp.i = a.r*b.i+a.i*b.r;
    return temp;
    }
    public void ComplexAdd(ComplexNumber c){
    this.r=this.r+c.r;
    this.i=this.i+c.i;
    } public void ComplexMinus(ComplexNumber c){
    this.r=this.r-c.r;
    this.i=this.i-c.i;
    }
    public void ComplexMulti(ComplexNumber c)
    {
    double temp=this.r;
    this.r=this.r*c.r-this.i*c.i;
    this.i =temp*c.i+this.i*c.r;
    }
    public void printComplexNumber(){
    System.out.print(""+this.r+"+"+this.i+"i");
    } }
  • 测试代码

    import static junit.framework.Assert.*;import junit.framework.TestCase;import org.junit.Test;publicclass ComplexNumberTest extends TestCase {
    ComplexNumber c1 = newComplexNumber(3,5);
    ComplexNumber c2 = newComplexNumber(3,5);
    double a = 5;
    @TestpublicvoidtestAdd1() throws Exception {
    c1.ComplexAdd(c2);
    assertEquals(6.0, c1.getRealPart());
    assertEquals(10.0, c1.getImaginPart());
    }
    @TestpublicvoidtestAdd2() throws Exception {
    c1.ComplexAdd(a);
    assertEquals(8.0, c1.getRealPart());
    assertEquals(5.0, c1.getImaginPart());
    }
    @TestpublicvoidtestMinus1() throws Exception {
    c1.ComplexMinus(c2);
    assertEquals(0.0, c1.getRealPart());
    assertEquals(0.0, c1.getImaginPart());
    }
    publicvoidtestMinus2() throws Exception {
    c1.ComplexMinus(a);
    assertEquals(-2.0, c1.getRealPart());
    assertEquals(5.0, c1.getImaginPart());
    }
    @TestpublicvoidtestMulti1() throws Exception {
    c1.ComplexMulti(c2);
    assertEquals(9.0, c1.getRealPart());
    assertEquals(25.0, c1.getImaginPart());
    }
    publicvoidtestMulti2() throws Exception {
    c1.ComplexMulti(a);
    assertEquals(15.0, c1.getRealPart());
    assertEquals(5.0, c1.getImaginPart());
    }
    }

    测试代码运行结果:

实验心得体会

本次实验一开始不懂TDD和UML的意思,以为是多么高深莫测的知识,后来在同学的帮助下一点一点实验,发现其实就是一种检验代码的方法和把java语言模块化,

而且运用好单元测试可以在未来的程序设计中让自己负责的模块功能定义尽量明确,最关键的是建立了测试代码的思维方式,还是有很多收获的。

PSP(Personal Software Process)

步骤 耗时 百分比
需求分析 5 mins 8%
设计 20 mins 33%
代码实现 20 mins 33%
测试 5 mins 8%
分析总结 10 mins 16%

20145239杜文超 《Java程序设计》实验二 Java面向对象程序设计实验报告的更多相关文章

  1. 20145239 杜文超 实验四 Android开发基础

    20145239实验四 Android开发基础 实验内容 基于Android Studio开发简单的Android应用并部署测试 了解Android组件.布局管理器的使用 掌握Android中事件处理 ...

  2. 20145239杜文超《网络对抗》- Web安全基础实践

    20145239杜文超<网络对抗>- Web安全基础实践 基础问题回答 (1)SQL注入攻击原理,如何防御? SQL注入攻击就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查 ...

  3. 20145239杜文超《网络对抗》- Web基础

    20145239杜文超<网络对抗>- Web基础 基础问题回答 1.什么是表单? 表单是一个包含表单元素的区域. 表单元素是允许用户在表单中(比如:文本域.下拉列表.单选框.复选框等等)输 ...

  4. 20145239杜文超《网络攻防》- MSF基础应用

    20145239杜文超<网络攻防>- MSF基础应用 基础问题回答 1.用自己的话解释什么是exploit,payload,encode? exploit:实现攻击行为的主体,但没有载荷只 ...

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

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

  6. 20145239杜文超《网络对抗》- shellcode注入&Return-to-libc攻击深入

    20145239杜文超<网络对抗>- shellcode注入&Return-to-libc攻击深入 shellcode基础知识 Shellcode是一段代码,作为数据发送给受攻击服 ...

  7. 20145239杜文超 实验五 Java网络编程

    20145239 实验五 Java网络编程 实验内容 组队,一人服务器,一人客户端. 下载加解密代码,先编译运行代码,一人加密一人解密,适当修改代码. 然后集成代码,一人加密后通过TCP发送,加密使用 ...

  8. 20145239杜文超 《Java程序设计》第7周学习总结

    20145239 <Java程序设计>第7周学习总结 教材学习内容总结 Lambda 认识Lambda语法 Lambda语法概述: Arrays的sort()方法可以用来排序,在使用sor ...

  9. 20145239杜文超 《Java程序设计》第1周学习总结

    20145239<Java程序设计>第1周学习总结 教材学习内容总结 第一周. 通过教材简单的了解了java的历史.因为之前看过视频,所以有一个大致明了的认识. 识记了Java三大平台:J ...

随机推荐

  1. 启动mongodb报错问题

    [root@zk-datanode-02 mongodb]# bin/mongod -f config/mongo.cnf &[1] 30549[root@zk-datanode-02 mon ...

  2. EasyUI+zTree实现简单的树形菜单切换

    使用easyui_ztree实现简单的树形菜单切换效果 <!DOCTYPE html> <html> <head> <meta charset="U ...

  3. 2016.6.21 将Eclipse中项目部署到tomcat下

    新建的web项目,各种都配置好,选择run on server之后,发现运行失败,并不能访问需要的网址.而脱离eclipse,将生成的war文件直接放到tomcat的webapp下时,可以正常访问.所 ...

  4. AutoCAD 样条曲线如何结束

    如下所示,走了四个点之后曲线绘制结束想要闭合了   鼠标右击选择确认   然后变成下面这个样子,鼠标再右击就可以结束(然后又回从下面伸出来东西,还是右击)总之就是想要结束的时候:右击确认,不断右击   ...

  5. C 错误处理

    C 错误处理 C 语言不提供对错误处理的直接支持,但是作为一种系统编程语言,它以返回值的形式允许您访问底层数据.在发生错误时,大多数的 C 或 UNIX 函数调用返回 1 或 NULL,同时会设置一个 ...

  6. merge-sorted-array——合并两个有序数组

    Given two sorted integer arrays A and B, merge B into A as one sorted array. Note: You may assume th ...

  7. 让heigh:100%起作用

    如何让 height:100%; 起作用 http://www.webhek.com/css-100-percent-height     当你设置一个页面元素的高度(height)为100%时,期望 ...

  8. (二)关于jQuery

    jQuery是一个快速.简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架).jQuery设计的宗旨是“write Less, ...

  9. 摄像机Rtsp地址格式大全

    各厂家rtsp地址格式如下:  一. 海康.中威摄像机 格式1 主码流:rtsp://admin:12345@192.168.1.64:554/Streaming/Channels/1 子码流:rts ...

  10. MySQL系列:innodb源代码分析之线程并发同步机制

    innodb是一个多线程并发的存储引擎,内部的读写都是用多线程来实现的,所以innodb内部实现了一个比較高效的并发同步机制. innodb并没有直接使用系统提供的锁(latch)同步结构,而是对其进 ...