标签:
北京电子科技学院(BESTI)
实 验 报 告
课程:Java程序设计 班级:1352 姓名:杨光 学号:20135233
成绩: 指导教师:娄嘉鹏 实验日期:2015.5.8
实验密级: 预习程度: 实验时间:
仪器组次:33 必修/选修:选修 实验序号:2
实验名称: Java面向对象程序设计
实验目的与要求:实验内容
1. 初步掌握单元测试和TDD
2. 理解并掌握面向对象三要素:封装、继承、多态
3. 初步掌握UML建模
4. 熟悉S.O.L.I.D原则
5. 了解设计模式
实验要求
1.没有Linux基础的同学建议先学习《Linux基础入门(新版)》《Vim编辑器》 课程
2.完成实验、撰写实验报告,实验报告以博客方式发表在博客园,注意实验报告重点是运行结果,遇到的问题(工具查找,安装,使用,程序的编辑,调试,运行等)、解决办法(空洞的方法如“查网络”、“问同学”、“看书”等一律得0分)以及分析(从中可以得到什么启示,有什么收获,教训等)。报告可以参考范飞龙老师的指导
3. 严禁抄袭,有该行为者实验成绩归零,并附加其他惩罚措施。
4. 请大家先在实验楼中的~/Code目录中用自己的学号建立一个目录,代码和UML图要放到这个目录中,截图中没有学号的会要求重做,然后跟着下面的步骤练习
实验仪器:
名称 |
型号 |
数量 |
PC |
hp惠普 |
1 |
|
|
|
实验步骤
(一)单元测试
实验结果
修改MyUtil中代码,使条变成绿色
(二)面向对象三要素
实验结果
练习
实验步骤
1使用TDD的方式设计关实现复数类Complex.
2.实验报告中统计自己的PSP(Personal Software Process)时间
3. 实现要有伪代码,产品代码,测试代码。
4.总结单元测试的好处
实验代码
了解:
1)复数类ComplexNumber的属性
realPart: 实部,代表复数的实数部分
imaginPart: 虚部,代表复数的虚数部分
2)复数类ComplexNumber的方法
ComplexNumber() 构造函数,将实部,虚部都置为0
ComplexNumber(double r, double i) 构造函数,创建复数对象的同时完成复数的实部,虚部的初始化
getRealPart() 获取实部
getImaginaryPart() 获取虚部
getRealPart(double d) 设置实部
getImaginaryPart(double d) 设置虚部
add(ComplexNumber c) 复数相加
add(double c) 复数相加
minus(ComplexNumber c) 复数相减
minus(double c) 复数相减
ComplexMulti(ComplexNumber c) 复数相乘
ComplexMulti(double c) 复数相乘
toString() 把当前复数对象的实部,虚部组合成a+bi的字符串形式
伪代码:
//复数类
类有虚部实部
复数的加法运算;
复数的减法运算;
复数的乘法运算;
复数的除法运算;
产品代码:
public class ComplexDemo {
// main方法
public static void main(String[] a) {
Complex b = new Complex(2, 5);
Complex c = new Complex(3, -4);
System.out.println(b + "+" + c + "=" + b.add(c));
System.out.println(b + "-" + c + "=" + b.minus(c));
System.out.println(b + "*" + c + "=" + b.multiply(c));
System.out.println(b + "/" + c + "=" + b.divide(c));
}
}
// Complex类
class Complex {
private double m;// 实部
private double n;// 虚部
public Complex(double m, double n) {
this.m = m;
this.n = n;
}
// add
public Complex add(Complex c) {
return new Complex(m + c.m, n + c.n);
}
// minus
public Complex minus(Complex c) {
return new Complex(m - c.m, n - c.n);
}
// multiply
public Complex multiply(Complex c) {
return new Complex(m * c.m - n * c.n, m * c.n + n * c.m);
}
// divide
public Complex divide(Complex c) {
double d = Math.sqrt(c.m * c.m) + Math.sqrt(c.n * c.n);
return new Complex((m * c.m + n * c.n) / d, Math.round((m * c.n - n * c.m) / d));
}
public String toString() {
String rtr_str = "";
if (n > 0)
rtr_str = "(" + m + "+" + n + "i" + ")";
if (n == 0)
rtr_str = "(" + m + ")";
if (n < 0)
rtr_str = "(" + m + n + "i" + ")";
return rtr_str;
}
}
测试代码:
public static ComplexTest{
public static void main(String[] args){
class Complex {
private double m;// 实部
private double n;// 虚部
public Complex(double m, double n) {
this.m = m;
this.n = n;
}
public String toString() {
String rtr_str = "";
if (n > 0)
rtr_str = "(" + m + "+" + n + "i" + ")";
if (n == 0)
rtr_str = "(" + m + ")";
if (n < 0)
rtr_str = "(" + m + n + "i" + ")";
return rtr_str;
}
}
}
}
步骤 |
耗时 |
百分比 |
需求分析 |
30min |
21% |
设计 |
20min |
14% |
代码实现 |
1h |
42% |
测试 |
30min |
21% |
分析总结 |
|
|
单元测试检测代码是否有bug,可能会出现问题的地方,单元检测发现问题很快速。
实验收获
对虚拟机的使用更加熟悉,也熟悉了单元检测的使用,以后的代码应该尽量避免bug出现,就是实验耗时有点长
标签:
原文地址:http://www.cnblogs.com/yg137565645/p/4486615.html