2016-2017-2 实验报告目录:   1   2   3   4   5



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

 课程名称:《程序设计与数据结构》

 学生班级:1623班

 学生姓名:刘伟康

 学生学号:20162330

 实验时间:2017年4月14日

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

 指导老师:娄嘉鹏、王志强老师


 实验内容:

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

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

  • 3.初步掌握UML建模;

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

  • 5.了解设计模式。

实验要求:

  • 1.没有Linux基础的同学建议先学习《Linux基础入门(新版)》《Vim编辑器》 课程

  • 2.完成实验、撰写实验报告,实验报告以博客方式发表在博客园,注意实验报告重点是运行结果,遇到的问题(工具查找,安装,使用,程序的编辑,调试,运行等)、解决办法(空洞的方法如“查网络”、“问同学”、“看书”等一律得0分)以及分析(从中可以得到什么启示,有什么收获,教训等)。报告可以参考范飞龙老师的指导;

  • 3.严禁抄袭,有该行为者实验成绩归零,并附加其他惩罚措施;

  • 4.请大家先在实验楼中的~/Code目录中用自己的学号建立一个目录,代码和UML图要放到这个目录中,截图中没有学号的会要求重做,然后跟着下面的步骤练习。

实验步骤:

前期准备:

  • 1.预先安装好IDEA,并配置好环境变量。

  • 2.预先安装好UML类图。

需求分析:

  • 1.需要初步掌握单元测试和TDD;

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

  • 3.需要初步掌握UML建模;

  • 4.需要理解S.O.L.I.D原则和设计模式;

代码实现:

1.用TDD测试代码(成绩):(只举一例)
新建MyUtil.java

public class MyUtil{
   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 "错误";
   }
}

新建一个测试用例类MyUtilTest

import org.junit.Test;
import junit.framework.TestCase;
public class MyUtilTest extends TestCase {
    @Test
    public void testNormal() {
        assertEquals("不及格", MyUtil.percentage2fivegrade(55));
        assertEquals("及格", MyUtil.percentage2fivegrade(65));
        assertEquals("中等", MyUtil.percentage2fivegrade(75));
        assertEquals("良好", MyUtil.percentage2fivegrade(85));
        assertEquals("优秀", MyUtil.percentage2fivegrade(95));
    }
}

结果:出现绿条。

2.以TDD的方式研究学习StringBuffer:(只举一例)

 public class StringBufferDemo{
   public static void main(String [] args){
       StringBuffer buffer = new StringBuffer();
       buffer.append('S');
       buffer.append("tringBuffer");
//     System.out.println(buffer.charAt(1));
       System.out.println(buffer.capacity();
//     System.out.println(buffer.indexOf("tring12345"));
       System.out.println("buffer = " + buffer.toString());
      System.out.println(buffer.length());
  }
}    

测试结果:

34
buffer = StringBuffer
17

3.让系统支持Byte类,并在MyDoc类中添加测试代码:

详见此链接

4.以TDD的方式开发一个复数类Complex(还未完成)

5.使用StarUML对实验二中的代码进行建模:(如下图)

测试过程及遇到的问题:

1.用TDD测试代码(成绩):

  • 先用IDEA进行的一些测试:


  • 边界值问题的解决:



  • 使用TDD测试,注意最开始出现找不到包之类的错误,需要在Structure当中导入包:

  • 运行结果:
    说明:
    1.增加测试代码,JUnit出现红条;
    2.修改产品代码,JUnit出现绿条;
    3.增加了两个测试边界:testBoundary,testException,出现绿条。

2.以TDD的方式研究学习StringBuffer:

  • 运行结果:

其中遇到的问题:

  • 在面向程序设计实验(二)中,不理解buffer.indexOf的作用。

  • 问题解决方案:(搜索)(猜测)
    看名字大致意思是什么的索引,在API上查找了没有,之后就开始搜索。
    搜索到的大致内容是:字符串的IndexOf()方法搜索在该字符串上是否出现了作为参数传递的字符串,如果找到字符串,则返回字符的起始位置 (0表示第一个字符,1表示第二个字符依此类推)如果说没有找到则返回 -1 。(注意索引从1开始)
    这次我尝试了一下:
    先由于没有找到该字符串,所以结果预计为-1(成功):
  • 之后尝试了Buffer类型,B刚好是第六个字符,所以输出为6:

3.让系统支持Byte类,并在MyDoc类中添加测试代码:
代码在上面已贴出,运行结果如下:

4.以TDD的方式开发一个复数类Complex(还未完成)

5.在使用UML类图的过程中,也遇到一些问题,不过没什么妨碍,已基本解决。(结果图在上面已贴出)

分析总结:

  • 本周的实验课非常充实,虽然解决问题耗费了不少时间,但是对应的收获也很多。单元测试和TDD让我了解到测试代码的另一种方式,虽然TDD有些麻烦,但是基于TDD,我们不会出现过度设计的情况。
    TDD的一般步骤如下:

    • 明确当前要完成的功能,记录成一个测试列表
    • 快速完成编写针对此功能的测试用例
    • 测试代码编译不通过(没产品代码呢)
    • 编写产品代码
    • 测试通过
  • 除此之外,感觉这次实验有些仓促,没能完成Complex设计,不过之前的几个例子仍然加深了我对SOLID原则和面向对象设计原则的理解。
    我还是想说,现在多尝试总是有益的,当我掌握了足够熟练的语法,有了足够清晰的设计思路的时候,才能具备一个合格程序员最基本的素养,继续安排好时间,多实践吧!

PSP(Personal Software Process)时间统计:

步骤 耗时 百分比
需求分析 40min 16%
设计 80min 32%
代码实现 60min 24%
测试 40min 16%
分析总结 30min 12%

参考资料:

20162330 实验二 《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. 实验二Java面向对象程序设计实验报告(2)

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

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

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

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

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

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

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

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

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

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

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

  10. 20145239杜文超 《Java程序设计》实验二 Java面向对象程序设计实验报告

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

随机推荐

  1. Python Web-第五周-Web Services and XML(Using Python to Access Web Data)

    1.Web Service Overview 1.Data on the Web Python Dictionary 和 Java HashMap间需要建立一个桥梁,可以用XML或是JSON 2.XM ...

  2. Splay入门解析【保证让你看不懂(滑稽)】

    BST真是神奇的东西... 而且种类好多呀... 我这个蒟蒻只学会了splay orzCJ老爷,各种树都会 好好好,不说了,直接说splay. 不知道splay是啥,,你也要知道平衡树是啥... 平衡 ...

  3. SA 后缀数组

    SA 后缀数组 首先一定要确定\(SA\)是个什么东西 \(SA[i]\)表示的是排名为\(i\)的后缀是哪一个 至于后缀\(i\)的排名是多少,那个是\(rank[i]\) 当然啦 最最最难懂的就是 ...

  4. [HNOI2014]米特运输

    显然知道一个节点就可以推出整棵树 然而直接乘会爆longlong 所以考虑取log 最后排序算众数即可 # include <stdio.h> # include <stdlib.h ...

  5. canvas画布,时钟

    原理代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...

  6. 基于netcore实现mongodb和ElasticSearch之间的数据实时同步的工具(Mongo2Es)

    基于netcore实现mongodb和ElasticSearch之间的数据实时同步的工具 支持一对一,一对多,多对一和多对多的数据传输方式. 一对一 - 一个mongodb的collection对应一 ...

  7. 智能合约语言 Solidity 教程系列2 - 地址类型介绍

    Solidity教程系列第二篇 - Solidity地址类型介绍. 写在前面 Solidity是以太坊智能合约编程语言,阅读本文前,你应该对以太坊.智能合约有所了解,如果你还不了解,建议你先看以太坊是 ...

  8. Linux新手的最佳包管理器

    一个 Linux 新用户应该知道他或她的进步源自于对 Linux 发行版的使用,而 Linux 发行版有好几种,并以不同的方式管理软件包. 在 Linux开发 中,包管理器非常重要,知道如何使用多种包 ...

  9. AVL树(Java实现)

    AVL树基本介绍 AVL树是一种自平衡的二叉查找树,在AVL树中任何节点的两个子树的高度差不能超过1.就是相当于在二叉搜索树的基础上,在插入和删除时进行了平衡处理. 不平衡的四种情况 LL:结构介绍 ...

  10. 剑指Offer-删除链表中重复的结点

    package LinkedList; /** * 删除链表中重复的结点 * 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针. * 例如,链表1-> ...