結對作業——四則運算

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章