項目倉庫地址: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