一、编码标准

  • 编程标准包含:具有说明性的名字、清晰的表达式、直截了当的控制流、可读的代码和注释,以及在追求这些内容时一致地使用某些规则和惯用法的重要性。

下面是没有最基本的缩进的一个程序:

public class CodeStandard {
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("tring"));
System.out.println("buffer = " + buffer.toString());
if(buffer.capacity()<20)
buffer.append("1234567");
for(int i=0; i<buffer.length();i++)
System.out.println(buffer.charAt(i));
}
}

在IDEA中选中Code→Reformate Code,将代码按IDEA的规范缩进,看起来就好了很多:

Code菜单中除了Reformate Code外,还有很多实用的功能。个人觉得比较好用方便的是Move Line Down(Alt+Shift+↓)和Move Line Up(Alt+Shift+↑),用快捷键更方便。

任务二:下载搭档实验二的Complex代码,加入不少于三个JUnit单元测试用例

搭档编写的Complex类如下:

根据她的代码编写ComplexTest,加入不少于三个单元测试用例,代码如下:

package week9;

import junit.framework.TestCase;
import org.junit.Test; import static org.junit.Assert.*; /**
* Created by lxkj on 2017/5/4.
*/
public class ComplexTest28 extends TestCase {
Complex c1 = new Complex(0.0, 3.0);
Complex c2 = new Complex(-1.0, -1.0);
Complex c3 = new Complex(-5.0, 2.0);
@Test
public void testAdd2(){
assertEquals(new Complex(-2.0,-2.0),c2.ComplexAdd(c2));
//自加
// assertEquals(new Complex(-1.0,2.0),c2.ComplexAdd(c1));
// assertEquals("-5.0+5.0i", c1.ComplexAdd(c3).toString());
assertEquals("-1.0+2.0i", c2.ComplexAdd(c1).toString());
// assertEquals("-1.0+2.0i", c1.ComplexAdd(c2).toString());
}
@Test
public void testSub2(){
assertEquals("7.3+0.3999999999999999i", new Complex(2.3,2.4).ComplexSub(c3).toString());
assertEquals("2.0 -1.0i", c2.ComplexSub(new Complex(-3.0,0.0)).toString());
}
//普通减法
@Test
public void testMulti2(){
assertEquals("-5.0+4.0i", c3.ComplexMulti(new Complex(1.0,2.0)).toString());
}
//自乘
@Test
public void testDiv2(){
assertEquals("1.5+4.0i", c3.ComplexDiv(c2).toString());
//自除
assertEquals("0.0", c1.ComplexDiv(new Complex(1.0,0.0)).toString());
assertEquals("0.0", c2.ComplexDiv(c1).toString());
//边缘测试
} }

任务三:下载搭档的代码,至少进行三项重构

重构,是让我们在不为系统带来新的bug的前提下,使其更加易于阅读、易于维护和易于变更。

选择了搭档简易计算器的代码,重构如下:

package week11;

/**
* Created by DELL on 2017/5/2.
*/
public class Calc2 {
public static void main(String [] args) { int result = 0;
boolean flag=false;
double out = 0;
double a = 0, b = 0;
if (args.length != 3) {
System.out.println("Usage: java Calc operato1 operand(+ - * / %) operator2");
} //+ - x / 和%运算
int x, y;
x = Integer.parseInt(args[0]);
y = Integer.parseInt(args[2]);
a = Double.parseDouble(args[0]);
b = Double.parseDouble(args[2]);
switch (args[1]) {
case "+":
result = add(x, y);
break;
case "-":
result = Sub(x, y);
break;
case "X":
out = Multi(a, b);
flag = true;
break;
case "/":
result = chu(x, y);
break;
case "%":
result = yu(x, y);
break;
default:
System.out.println("输入错误!");
break;
}
if (flag)
System.out.println(args[0] + " " + args[1] + " " + args[2] + " = " + out);
else
System.out.println(args[0] + " " + args[1] + " " + args[2] + " = " + result); }
public static int add(int x,int y){
return x+y;
}
public static int Sub(int x,int y){
return x-y;
}public static double Multi(double x,double y){
return x*y;
}public static int chu(int x,int y){
return x/y;
}public static int yu(int x,int y){
return x%y;
}
}

运行结果如下:

任务四:以结对的方式完成Java密码学相关内容的学习,结合重构、git、代码标准等

我和搭档在学习Java密码学相关内容之后,选择了RSA算法。

经过重构之后的截图如下:

实验遇到的问题及解决方案

  • 问题1: 把搭档的项目git clone下来之后,发现用自己的账号push到她的项目上之后就无法再次push到自己的项目上。

  • 解决方案: git现实的错误提示是远程仓库有的更新本地没有,需要进行git中的rebase。rebase之后再点击VCS→Update Project,之后再进行git add,commit,push,就可以推了。

实验体会与总结

本次实验算是第一次的结对编程实验,和搭档在结对编程的过程中Git出现了各种各样的错误,在网上查找了资料,也去问过了同学,总算是解决了,也算为以后的结对编程路打下了一点基石。希望以后能做的越来越好吧。

我的码云项目链接:20155328

搭档的码云项目链接:20155325

|步骤 |耗时 |百分比 |

| -------- | :----------------

20155328 《Java程序设计》实验三 敏捷开发与XP实践 实验报告的更多相关文章

  1. 20145308刘昊阳 《Java程序设计》实验三 敏捷开发与XP实践 实验报告

    20145308刘昊阳 <Java程序设计>实验三 敏捷开发与XP实践 实验报告 实验名称 敏捷开发与XP实践 实验内容 XP基础 XP核心实践 相关工具 统计的PSP(Personal ...

  2. 20165230 《Java程序设计》实验三 敏捷开发与XP实践 实验报告

    20165230 <Java程序设计>实验三 敏捷开发与XP实践 实验报告 一.实验报告封面 课程:Java程序设计 班级:1652班 姓名:田坤烨 学号:20165230 成绩: 指导教 ...

  3. 20155207王雪纯 《Java程序设计》实验三 敏捷开发与XP实践 实验报告

    20155207王雪纯 <Java程序设计>实验三 敏捷开发与XP实践 实验报告 实验名称 敏捷开发与XP实践 实验内容 XP基础 XP核心实践 相关工具 统计的PSP(Personal ...

  4. 2016-2017-2 20155339 《Java面向对象程序设计》实验三敏捷开发与XP实践实验报告

    2016-2017-2 20155339 <Java面向对象程序设计>实验三敏捷开发与XP实践实验报告 实验内容 XP基础 XP核心实践 相关工具 实验内容 一.在IDEA中使用工具(Co ...

  5. 20162311 实验三 敏捷开发与XP实践 实验报告

    20162311 实验三 敏捷开发与XP实践 实验报告 实验内容 一.研究学习IDEA中的Code菜单 使用Code ->Reformate Code功能将以下代码格式化 public clas ...

  6. 20165308实验三 敏捷开发与XP实践实验报告

    实验三 敏捷开发与XP实践实验报告 实验目的 安装 alibaba 插件,解决代码中的规范问题.再研究一下Code菜单,找出一项让自己感觉最好用的功能. 在码云上把自己的学习搭档加入自己的项目中,确认 ...

  7. 20155220 实验三 敏捷开发与XP实践 实验报告

    20155220 实验三 敏捷开发与XP实践 实验报告 实验内容 XP基础 XP核心实践 相关工具 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim ...

  8. # 20155224 实验三 敏捷开发与XP实践 实验报告

    20155224 实验三 敏捷开发与XP实践 实验报告 实验内容 XP基础 XP核心实践 相关工具 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim ...

  9. 20155226 实验三 敏捷开发与XP实践 实验报告

    20155226 实验三 敏捷开发与XP实践 实验报告 实验内容 XP基础 XP核心实践 相关工具 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim ...

  10. 20155311 实验三 敏捷开发与XP实践 实验报告

    20155311 实验三 敏捷开发与XP实践 实验报告 实验内容 XP基础 xp核心工具 相关工具 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim ...

随机推荐

  1. 相同数据源情况下,使用Kafka实时消费数据 vs 离线环境下全部落表后处理数据,结果存在差异

    原因分析: 当某个consumer宕机时,消费位点(例如2s提交一次)尚未提交到zookeeper,此时Kafka集群自动rebalance后另一consumer来接替该宕机consumer继续消费, ...

  2. 常用算法的C++实现

    常用算法的C++实现 // // DZAppDelegate.m // AlgorithmTest // // Created by dzpqzb on 13-8-4. // Copyright (c ...

  3. 项目管理利器-Maven(Windows安装)

    什么是Maven? 安装Maven环境: 下载地址:https://maven.apache.org/download.cgi Maven3.3+JDK1.7以上版本 下载windows版本 解压到本 ...

  4. Mint-ui 中 Popup 作为组件引入,控制弹出框的显示与隐藏遇到的问题。

    Popup组件的结构: <template>   <div>   <!--分享弹出窗 begin-->     <mt-popup class="s ...

  5. Java基础知识强化之多线程笔记07:同步、异步、阻塞式、非阻塞式 的联系与区别

    1. 同步: 所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回.但是一旦调用返回,就必须先得到返回值了. 换句话话说,调用者主动等待这个"调用"的结果. 对于 ...

  6. 面向对象的JavaScript --- 封装

    面向对象的JavaScript --- 封装 封装 封装的目的是将信息隐藏.一般而言,我们讨论的封装是封装数据和封装实现.真正的封装为更广义的封装,不仅包括封装数据和封装实现,还包括封装类型和封装变化 ...

  7. UVa 10735 - Euler Circuit(最大流 + 欧拉回路)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  8. 【转】Faster RCNN 原理

    看过好几篇讲Faster RCNN的文章,有一些基础以后,看这个文章是最好的. https://www.cnblogs.com/wangyong/p/8513563.html

  9. Graph I - Graph

    Graph There are two standard ways to represent a graph G=(V,E)G=(V,E), where VV is a set of vertices ...

  10. 对极几何(Epipolar Geometry)

    基本概念 对极几何(Epipolar Geometry)是Structure from Motion问题中,在两个相机位置产生的两幅图像的之间存在的一种特殊几何关系,是sfm问题中2D-2D求解两帧间 ...