20165219 《Java程序设计》实验三(敏捷开发与XP实践)实验报告

一、实验报告封面

课程:Java程序设计 班级:1652班 姓名:王彦博 学号:20165219 成绩:

指导教师:娄嘉鹏 实验日期:2018年4月30日

实验时间:15:45 - 17:20

实验序号:实验三

实验名称:敏捷开发与XP实践

实验内容:

  1. XP基础

  2. XP核心实践

  3. 相关工具

实验要求:

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

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

3 实验报告中统计自己的PSP(Personal Software Process)时间;

4 严禁抄袭。

二、实验内容及步骤

(一)alibaba 插件与Code菜单

Move Line/statement Down/Up:将某行、表达式向下、向上移动一行

suround with:用 try-catch,for,if等包裹语句

comment with line/block comment:把选中它区域变成注释

show reformat file dialog:按照格式自动对齐

Optimize imports:优化imports

Insert Live Template:插入 Live Template 缩写

例如:comment with line/block comment,把代码中选中的部分变成注释

(二)Complex代码添加测试用例

同伴代码

public class Complex {
// 定义属性并生成getter,setter
private double r;
private double i; // 定义构造函数
public Complex(double r, double i) {
this.r = r;
this.i = i;
} public static double getRealPart(double r) {
return r;
} public static double getImagePart(double i) {
return i;
} //Override Object
public boolean equals(Object obj) { Complex complex = (Complex) obj;
if (complex.r != r) {
return false;
}
if (complex.i != i) {
return false;
}
return true;
} public String toString() {
String str = new String();
if (i == 0) str = r + "";
else if (i < 0) str = r + "" + i + "i";
else str = r + "" + "+" + i + "i";
return str;
} // 定义公有方法:加减乘除
Complex ComplexAdd(Complex a) {
return new Complex(r + a.r, i + a.i);
} Complex ComplexSubtract(Complex a) {
return new Complex(r - a.r, i - a.i);
} Complex ComplexMultiply(Complex a) {
return new Complex(r * a.r - i * a.i, r * a.i + i * a.r);
} Complex ComplexDivide(Complex a) {
return new Complex((r * a.r + i * a.i) / (a.r * a.r + a.i * a.i), (i * a.r - r * a.i) / (a.r * a.r + a.i * a.i));
}
}

添加测试用例

import junit.framework.TestCase;
import org.junit.Test;
import static org.junit.Assert.*;
public class ComplexTest extends TestCase {
Complex a=new Complex(1,2);
Complex b=new Complex(-2,-1);
Complex d=new Complex(4,-2);
@Test
public void testequals(){
assertEquals(false,a.equals(b));
assertEquals(false,b.equals(c));
assertEquals(true,new Complex(1.0,2.0).equals(a));
} @Test
public void testAdd(){
assertEquals(new Complex(-1,1),a.ComplexAdd(b));
assertEquals(new Complex(5,0),a.ComplexAdd(c));
}
@Test
public void testSubtract(){
assertEquals(new Complex(3,3),a.ComplexSubtract(b));
assertEquals(new Complex(-3,4),a.ComplexSubtract(c));
}
@Test
public void testMultiply(){
assertEquals(new Complex(0,-5),a.ComplexMultiply(b));
assertEquals(new Complex(17,4),new Complex(3,2.5).ComplexMultiply(c));
}
@Test
public void testDivide(){
assertEquals(new Complex(0,0.5),a.ComplexDivide(c));
assertEquals(new Complex(-2,-1),b.ComplexDivide(new Complex(1,0)));
}
}

测试通过的截图

git log的截图

(三)重构

Rename可以给类、包、方法、变量改名字,增加代码的可读性。

Refactor->Encapsulate Field...用来封装成员变量

Source->Generate toString()...用来产生一个toString方法

(四)以结对方式完成Java密码学的学习

凯撒密码的密钥是3,算法是将普通字母表中的字母用密钥对应的字母替换

凯撒密码的加密过程可记为如下一个变换:

c≡m+k mod n (其中n为基本字符个数)

同样,解密过程可表示为:

m≡c+k mod n (其中n为基本字符个数)

成果如下:

重构

将Code,Rename为Caesar,并为p赋初值0

三、实验体会

通过本次实验,又一次体会到了结对编程的魅力,通过学习重构代码,也理解了,代码的规范性以及可读性的重要意义。

四、PSP

步骤 耗时 百分比
需求分析 20min 8%
设计 60min 25%
代码实现 120min 50%
测试 10min 4%
分析总结 30min 13%

最新文章

  1. 同上! 下拉复选框 点击当前的checkbox 选中后面li 添加到指定区域
  2. Maps for Developers
  3. Static Const
  4. Verilog语法基础讲解之参数化设计
  5. MySQL占用内存过大的问题解决
  6. bzoj2595
  7. java 面向对象——进度1
  8. 用sed、awk、grep同时匹配多个条件(与模式、或模式)
  9. Cloudera impala简单介绍及安装具体解释
  10. java调用C/C++写的dll(转)
  11. 庞玉栋:浅谈seo优化对于网站建设的重要性
  12. Web测试——翻页功能测试用例
  13. Hive中数据的导入与导出
  14. Java CAS同步机制 原理详解(为什么并发环境下的COUNT自增操作不安全): Atomic原子类底层用的不是传统意义的锁机制,而是无锁化的CAS机制,通过CAS机制保证多线程修改一个数值的安全性。
  15. android查看屏幕密度,分辨率的shell命令
  16. luogu1169 棋盘制作 (单调栈)
  17. 如何在Ubuntu 16.04上安装配置Redis
  18. OpenStack云桌面系列【2】—OpenStack和Spice
  19. System.ComponentModel.DataAnnotations.Schema 冲突
  20. jQuery类名添加click方法

热门文章

  1. float型数据与字节数组的转化
  2. JavaScript笔记——正则表达式
  3. 实战MvcPager(PagerOptions自定义样式&amp;同、异步)
  4. kali下安装go环境
  5. Dev控件类似于ComBox的DropDownControl用法
  6. logistic回归和线性回归
  7. 吴恩达-AI-机器学习课后习题解析-第三周
  8. bash&amp;nbsp;shell笔记5&amp;nbsp;显示数据
  9. random和os模块
  10. 详解Django的 select_related 和 prefetch_related 函数对 QuerySet 查询的优化