项目仓库地址:https://dev.tencent.com/u/qingYinGuo/p/Arithmetic/git
搭档博客地址:https://blog.csdn.net/cimixian/article/details/89202883
前言
开始以为这个项目还是挺简单的,因为后台的逻辑已经都实现了,剩下的可能就是将开始软件的Java代码修改为业务逻辑层代码就行了。本以为就是简单的代码搬运,结果业务逻辑层的代码整整比原来的行数增长了一倍。
项目结构
后端接口及结构设计
项目是通过jsp+Servlet+Spring实现的。后端主要是采取MVC模式,故后端分为三层:controller负责前后台信息的交互控制,Service层负责业务逻辑的实现,entity负责对实体层的封装。
业务流程图
后端重要代码展示
1.因为由index.jsp向后台传数据是传了4个数据,为方便后台方法封装了Limit实体类,便于方法之间相互传值。
package com.entity;
/**
* @author Sunny
*/
public class Limit {
private int minNum;
private int maxNum;
private int count;//数量
private int symCount;//运算符个数
@Override
public String toString() {
return "Limit{" +
"minNum=" + minNum +
", maxNum=" + maxNum +
", count=" + count +
", symCount=" + symCount +
'}';
}
public int getMinNum() {
return minNum;
}
public void setMinNum(int minNum) {
this.minNum = minNum;
}
public int getMaxNum() {
return maxNum;
}
public void setMaxNum(int maxNum) {
this.maxNum = maxNum;
}
public int getCount() {
return count;
}
public void setCount(int count) {
this.count = count;
}
public int getSymCount() {
return symCount;
}
public void setSymCount(int symCount) {
this.symCount = symCount;
}
}
2.Servlet接口
//加减乘除和括号结合
if (fourArith.equals("1") && bracket.equals("1")) {
Limit limit = new Limit();
limit.setSymCount(symCount);
limit.setMaxNum(maxNum);
limit.setMinNum(minNum);
limit.setCount(count);
lists = arithmeticService.twoLimits1(limit);
formulaList = lists.get(0);
resultList = lists.get(1);
request.getSession().setAttribute("formulaList",formulaList);
request.getSession().setAttribute("resultList",resultList);
request.getRequestDispatcher("dati.jsp").forward(request,response);
try {
// request.getRequestDispatcher("/DownloadServlet").forward(request,response);
}catch (Exception e){
e.printStackTrace();
}
//只有括号
else if (!fourArith.equals("1") && bracket.equals("1")) {
Limit limit = new Limit();
limit.setSymCount(symCount);
limit.setMaxNum(maxNum);
limit.setMinNum(minNum);
limit.setCount(count);
lists = arithmeticService.addBracketToFront(limit);
formulaList = lists.get(0);
resultList = lists.get(1);
request.getSession().setAttribute("formulaList",formulaList);
request.getSession().setAttribute("resultList",resultList);
request.getRequestDispatcher("dati.jsp").forward(request,response);
//只有乘除
else if (fourArith.equals("1") && !bracket.equals("1")) {
Limit limit = new Limit();
limit.setSymCount(symCount);
limit.setMaxNum(maxNum);
limit.setMinNum(minNum);
limit.setCount(count);
lists = arithmeticService.fourArithToFront(limit);
formulaList = lists.get(0);
resultList = lists.get(1);
request.getSession().setAttribute("formulaList",formulaList);
request.getSession().setAttribute("resultList",resultList);
request.getRequestDispatcher("dati.jsp").forward(request,response);
}
//只有加减
else {
Limit limit = new Limit();
limit.setSymCount(symCount);
limit.setMaxNum(maxNum);
limit.setMinNum(minNum);
limit.setCount(count);
lists = arithmeticService.twoArithToFront(limit);
formulaList = lists.get(0);
resultList = lists.get(1);
request.getSession().setAttribute("formulaList",formulaList);
request.getSession().setAttribute("resultList",resultList);
//request.getSession().setAttribute("email",req.getParameter("email"));
request.getRequestDispatcher("dati.jsp").forward(request,response);
}
request.setAttribute("formulaList",formulaList);
request.setAttribute("resultList",resultList);
}catch (Exception e){
e.printStackTrace();
request.setAttribute("errMsg",e.toString());
}
}
分别调用service层不同的方法,以实现其功能。
3.为方便前台的传值方便,将答案和式子以list分开存储,同时为了保持式子和答案的一致性,重新生成方法,遍历原方法生成的式子,得出答案,重新存储到resultList,下列代码为生成括号的式子答案的计算,返回值是将式子和答案一起
public List<List> addBracketToFront(Limit limit){
List<String> formulaList=new ArrayList<>();
List<String> resultList=new ArrayList<>();
List<List> allList=new ArrayList<>();
for (int i=0;i<limit.getCount();i++){
List<String> list=addBracket(limit);
String formula=list.get(0);
String result=list.get(1);
formulaList.add(formula);
resultList.add(result);
allList.add(formulaList);
allList.add(resultList);
}
return allList;
}
Servlet再将allList分开,分别传给前台,此举是为了传参的便利。
总结
PSP2.1 | 任务内容 | 计划共完成需要的时间(min) | 实际完成需要的时间(min) |
Planning | 计划 | 10 | 16 |
· Estimate | · 估计这个任务需要多少时间,并规划大致工作步骤 | 10 | 16 |
Development | 开发 | 260 | 541 |
· Analysis | · 需求分析 (包括学习新技术) | 10 | 25 |
· Design Spec | · 生成设计文档 | 5 | 6 |
· Design Review | · 设计复审 (和同事审核设计文档) | 10 | 40 |
· Coding Standard | · 代码规范 (为目前的开发制定合适的规范) | 5 | 10 |
· Design | · 具体设计 | 10 | 15 |
· Coding | · 具体编码 | 60*3 | 60*6 |
· Code Review | · 代码复审 | 10 | 25 |
· Test | · 测试(自我测试,修改代码,提交修改) | 30 | 60 |
Reporting | 报告 | 35 | 80 |
· Test Report | · 测试报告 | 20 | 40 |
· Size Measurement | · 计算工作量 | 5 | 15 |
· Postmortem & Process Improvement Plan | · 事后总结, 并提出过程改进计划 | 10 | 25 |
本次结对项目的实现一共有两个途径:GUI和网页形式。介于我和金书都是对于网站方面更为熟悉,自然而然,本次作业选择以网页形式完成,金书负责前端,我负责后端。
恍惚记得一个公式,完成一个项目代码的时间,只占完成整个项目时间的1/3。这次的项目正验证了这个公式,由于逻辑简单,且已经在前面的作业中将逻辑实现了,这次的代码便变得很简单。但是,这次作业是结对作业,是要靠两个人的合作完成,我在写后端代码的时候,同时也应该考虑到前台的需求。所以两个人的沟通交流就显得异常重要。
此次作业,与我开始的目标是相距较远的。初始目标还想通过数据库完成历史纪录的功能,和登录注册的功能,由于时间原因也只能就此搁置了,但是后面我们还是会继续完善的。
金书的优点:耐心,细心,能力较强。而我,不够耐心,对于问题地讲解,很容易变得不耐烦,由于不够细心,在括号生成方面对运算符的控制,未做到准确,最后,金书和我一起花了一个下午的时间才成功改掉了这个bug。我对前台的了解不够,因此提出了很多有一些无厘头的要求,幸亏她跟我耐心地交流,我们才能一起完成这个项目。
谢谢我的搭档!
请使用手机"扫一扫"x