20165219 《Java程序设计》实验三(敏捷开发与XP实践)实验报告
一、实验报告封面
课程:Java程序设计 班级:1652班 姓名:王彦博 学号:20165219 成绩:
指导教师:娄嘉鹏 实验日期:2018年4月30日
实验时间:15:45 - 17:20实验序号:实验三
实验名称:敏捷开发与XP实践实验内容:
XP基础
XP核心实践
相关工具
实验要求:
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% |