版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、 .密 級(jí):內(nèi)部公開文檔編號(hào):1002 版 本 號(hào):V3.0測(cè)測(cè)(基于安卓平臺(tái)的測(cè)評(píng)軟件)軟件架構(gòu)設(shè)計(jì)文檔文件狀態(tài): 草稿 正在修改 正式發(fā)布文件標(biāo)識(shí):開發(fā)組當(dāng)前版本:V 3.0作 者:張放、張鈺若、陳國忠完成日期:2014-5-26中國石油大學(xué)(華東)計(jì)算機(jī)與通信工程學(xué)院 天師團(tuán)開發(fā)團(tuán)隊(duì) .頁腳. 項(xiàng)目名稱:測(cè)測(cè)基于安卓平臺(tái)測(cè)評(píng)軟件 版本: <V3.0>軟件架構(gòu)設(shè)計(jì)文檔 日期: <2014/5/26>修訂歷史記錄日期版本說明作者2014.5.13<V3.0>對(duì)軟件架構(gòu)進(jìn)行初始設(shè)計(jì)陳國忠,張放2014.5.23<V3.0>對(duì)軟件架構(gòu)進(jìn)行初始設(shè)計(jì)進(jìn)
2、行修正陳國忠,張放2014.5.26<V3.0>確定軟件架構(gòu)陳國忠,張放目錄1文檔介紹41.1文檔目的41.2文檔范圍41.3讀者對(duì)象41.4參考文獻(xiàn)42架構(gòu)設(shè)計(jì)思想53架構(gòu)體系描述54 views54.1 Module structs54.2 Component & Connector(組件-連接器視圖)74.3 Allocation85 Mappping between views85.1 Class map to Package85.2 Package map to Allocation86 Utility tree96.1 Quality attribute sce
3、nario (質(zhì)量屬性場(chǎng)景)96.2 Utility tree116.3 Tactics127. Architecture137.1 WebService137.2 MVC (Model View Controller)167.3 Publish/Subscrib181文檔介紹1.1文檔目的本文檔是對(duì)于測(cè)測(cè)軟件系統(tǒng)進(jìn)行詳細(xì)設(shè)計(jì)和編碼的重要依據(jù)。對(duì)該軟件的整個(gè)系統(tǒng)的結(jié)構(gòu)關(guān)系進(jìn)行了詳細(xì)描述,闡述了系統(tǒng)的總體框架,包括物理、邏輯結(jié)構(gòu),說明了體系結(jié)構(gòu)所采取的設(shè)計(jì)策略和所有技術(shù),并對(duì)相關(guān)內(nèi)容做出了統(tǒng)一的規(guī)定。為今后的設(shè)計(jì)、編碼、測(cè)試都提供了可以參考的模版并且提高效率,使整個(gè)開發(fā)過程做到資源利用最大化,減
4、少由于需求變更而修改的時(shí)間,大大的降低了成本,節(jié)約了時(shí)間,也使得客戶更加的滿意。1.2文檔范圍本文檔包含以下幾個(gè)部分:1、 架構(gòu)設(shè)計(jì)思想2、 架構(gòu)體系描述3、 系統(tǒng)模塊化分4、 系統(tǒng)模塊描述5、 模塊接口設(shè)計(jì)1.3讀者對(duì)象本文檔主要讀者包括:1、本系統(tǒng)的設(shè)計(jì)人員:包括模塊設(shè)計(jì)人員(理解用戶需求,在設(shè)計(jì)時(shí)把握用戶需求)。2、本系統(tǒng)的系統(tǒng)開發(fā)人員:編碼人員(了解用戶需求,為編碼提供模版)。3、本系統(tǒng)的測(cè)試人員(了解用戶需求,為測(cè)試提供參考)。4、 客戶(檢查是否滿足要求)。1.4參考文獻(xiàn)軟件工程講義測(cè)測(cè)需求規(guī)格說明書2架構(gòu)設(shè)計(jì)思想為了降低系統(tǒng)耦合度,增加系統(tǒng)內(nèi)聚性,在需求發(fā)生更改時(shí)能在較短的時(shí)間內(nèi)
5、對(duì)系統(tǒng)做出修改,并重新投入使用,我們決定以分層體系架構(gòu)風(fēng)格作為整個(gè)系統(tǒng)的體系風(fēng)格,嚴(yán)格按照一定的規(guī)則來進(jìn)行接口設(shè)計(jì),并以之為根據(jù)進(jìn)行詳細(xì)設(shè)計(jì)。分為數(shù)據(jù)層、業(yè)務(wù)邏輯層、表示層。3架構(gòu)體系描述整個(gè)系統(tǒng)頂層架構(gòu)采用分層的風(fēng)格,整個(gè)系統(tǒng)的體系結(jié)構(gòu)非常清晰,使得后期易于詳細(xì)設(shè)計(jì)、編碼、維護(hù)以及適應(yīng)需求變更。通過分層,定義出層與層之間的接口,使得在更加規(guī)范的同時(shí)擁有更為多臺(tái)花的接口描述,使得層與層之間的耦合度降低,增強(qiáng)了模塊的服用型和可擴(kuò)展性以及可維護(hù)性。同時(shí),分層也有益于項(xiàng)目模塊的劃分以及任務(wù)的分配,通過明確清晰的接口,降低集成的難度,提高效率。4 views4.1 Module structs(1)具
6、有三層結(jié)構(gòu)的測(cè)測(cè)軟件包圖:圖4.1.1領(lǐng)域模型圖(2)測(cè)測(cè)軟件領(lǐng)域模型圖:圖4.1.2領(lǐng)域模型圖(3)測(cè)測(cè)軟件類圖:圖4.1.3類圖(4)測(cè)測(cè)系統(tǒng)用例圖:圖4.1.4系統(tǒng)用例圖4.2 Component & Connector(組件-連接器視圖)(1)性格測(cè)試順序圖:圖4.2.1性格測(cè)試順序圖4.3 Allocation(1)測(cè)測(cè)軟件部署圖:圖4.3.1部署圖5 Mappping between views5.1 Class map to Package(1)類圖中的TTestController類、UserContainer類、TendencyContainer類對(duì)應(yīng)于包圖中表示層的
7、UI包。(2)類圖中的TTest類、User類、Test類、InteligentTest類、CharactTest類、Tendency類、Daily Trend類、ServiceController類對(duì)應(yīng)于包圖中業(yè)務(wù)邏輯層的測(cè)試模塊包和評(píng)價(jià)模塊包。(3)類圖中的DataHelp類、I/OEventStream類、QuestionBase類、UserInfo類對(duì)應(yīng)于包圖中數(shù)據(jù)層的題庫管理包和用戶管理包。5.2 Package map to Allocation(1)包圖中的UI包、測(cè)試模塊包、評(píng)價(jià)模塊包位于部署圖中的C/S客戶端。(2)包圖中的題庫管理包和用戶管理包位于部署圖中的客戶端數(shù)據(jù)庫和數(shù)
8、據(jù)庫服務(wù)器。6 Utility tree6.1 Quality attribute scenario (質(zhì)量屬性場(chǎng)景)(1)可用性:情節(jié)描述:用戶在進(jìn)行性格測(cè)試時(shí),點(diǎn)擊無反應(yīng)。相關(guān)質(zhì)量屬性: 可用性刺激源:進(jìn)行性格測(cè)試的用戶刺激:用戶點(diǎn)擊性格測(cè)試環(huán)境:正常運(yùn)行狀態(tài)制品:性格測(cè)試功能模塊反應(yīng):提示程序無響應(yīng),需重啟軟件反應(yīng)度量:在2s內(nèi)給出提示策略:異常檢測(cè)異常處理(2)互操作性:情節(jié)描述:用戶完成測(cè)試,進(jìn)行提交,數(shù)據(jù)庫返回測(cè)試結(jié)果。相關(guān)質(zhì)量屬性: 互操作性刺激源:進(jìn)行測(cè)試的用戶刺激:用戶完成測(cè)試,進(jìn)行提交環(huán)境:正常運(yùn)行狀態(tài)制品:數(shù)據(jù)庫、測(cè)試模塊反應(yīng):顯示測(cè)試結(jié)果反應(yīng)度量:在1s內(nèi)顯示測(cè)試結(jié)果。
9、策略:發(fā)現(xiàn)服務(wù)(3)可修改性:情節(jié)描述:開發(fā)人員更新數(shù)據(jù)庫相關(guān)質(zhì)量屬性:可修改性刺激源:開發(fā)人員刺激: 開發(fā)人員更新數(shù)據(jù)庫數(shù)據(jù)環(huán)境:正常運(yùn)行狀態(tài)制品:數(shù)據(jù)庫,反應(yīng):顯示測(cè)試結(jié)果反應(yīng)度量:在1s內(nèi)顯示測(cè)試結(jié)果。策略: 減少耦合提高內(nèi)聚封裝(4)性能:情節(jié)描述:用戶完成測(cè)試,提交,數(shù)據(jù)庫返回測(cè)試結(jié)果。相關(guān)質(zhì)量屬性:性能刺激源:進(jìn)行測(cè)試的用戶刺激: 開發(fā)人員更新數(shù)據(jù)庫數(shù)據(jù)環(huán)境:用戶完成測(cè)試,提交。制品:正常運(yùn)行狀態(tài)反應(yīng):顯示測(cè)試結(jié)果反應(yīng)度量:在1s內(nèi)顯示測(cè)試結(jié)果。策略:同時(shí)計(jì)算(5)安全性:情節(jié)描述:黑客侵入數(shù)據(jù)庫盜取用戶密碼。相關(guān)質(zhì)量屬性:安全性刺激源:黑客刺激: 黑客非法侵入數(shù)據(jù)庫環(huán)境:正常運(yùn)行
10、狀態(tài)制品:數(shù)據(jù)庫安全保護(hù)模塊反應(yīng):阻止黑客獲取數(shù)據(jù)庫內(nèi)容反應(yīng)度量:在1s內(nèi)進(jìn)行攔截策略: 拒絕攻擊反應(yīng)攻擊 確定用戶(6)可測(cè)試性情節(jié)描述:在開發(fā)階段開發(fā)者對(duì)自己的模塊進(jìn)行單元測(cè)試。相關(guān)質(zhì)量屬性:可測(cè)試性刺激源:開發(fā)人員刺激: 對(duì)已完成的子系統(tǒng)進(jìn)行測(cè)試環(huán)境:系統(tǒng)開發(fā)中制品:被測(cè)代碼段反應(yīng):顯示代碼出錯(cuò)情況反應(yīng)度量:執(zhí)行測(cè)試的時(shí)間不能超過2s策略: 限制復(fù)雜性(7)易用性情節(jié)描述:用戶在完成某一測(cè)試后重新進(jìn)行測(cè)試相關(guān)質(zhì)量屬性:易用性刺激源:欲進(jìn)行重新測(cè)試的用戶刺激: 用戶點(diǎn)擊重新測(cè)試環(huán)境:軟件正常運(yùn)行環(huán)境制品:相應(yīng)測(cè)試功能模塊反應(yīng):進(jìn)入該測(cè)試,顯示測(cè)試題反應(yīng)度量:重新跳轉(zhuǎn)到相應(yīng)測(cè)試界面的時(shí)間不超
11、過2s。6.2 Utility tree質(zhì)量屬性屬性細(xì)化場(chǎng)景 ASR性能題庫更新響應(yīng)時(shí)間在系統(tǒng)處于正常運(yùn)行時(shí),為對(duì)題庫更新做出響應(yīng),用戶更新題庫要在3分鐘內(nèi)完成(H,M)可維護(hù)性軟件更新軟件產(chǎn)商發(fā)布了一個(gè)新版本,必須盡快安裝該版本。(H,L)維護(hù)人員發(fā)現(xiàn)了軟件的缺陷,修復(fù)該bug。(H,M)安全性機(jī)密性完整性非維護(hù)人員侵入數(shù)據(jù)庫,需在1S內(nèi)完成攔截。(H,M)系統(tǒng)拒絕未經(jīng)登錄的訪問。(H,M)可用性發(fā)布新版本網(wǎng)絡(luò)環(huán)境不佳軟件產(chǎn)商發(fā)布了一個(gè)新軟件,該軟件是熱插拔的。(H,L)軟件產(chǎn)商發(fā)布了一個(gè)新軟件,支持用戶隨時(shí)進(jìn)行更新。(M,L)用戶進(jìn)行每日運(yùn)勢(shì)測(cè)評(píng)無響應(yīng),終端在1S內(nèi)提示用戶網(wǎng)絡(luò)環(huán)境不佳,請(qǐng)
12、打開網(wǎng)絡(luò)連接。(M,L)性能響應(yīng)時(shí)間吞吐量用戶提交測(cè)評(píng)后,系統(tǒng)在0.5s內(nèi)顯示測(cè)評(píng)結(jié)果。(M,H)100名用戶同時(shí)在線時(shí),系統(tǒng)每秒能處理150個(gè)正常請(qǐng)求。(M,H)可修改性優(yōu)化算話的復(fù)雜性優(yōu)化測(cè)評(píng)結(jié)果分析算法,兩名開發(fā)人員在一個(gè)工作日內(nèi)完成。(H,L)6.3 Tactics一,安全性策略: 1、反應(yīng)攻擊 2、確定用戶二,可用性策略: 1、異常檢測(cè) 2、異常處理3、實(shí)時(shí)監(jiān)聽三,安全性策略1、加密數(shù)據(jù)2、拒絕攻擊3、反應(yīng)攻擊4、確定用戶四,可修改性策略1、降低依賴2、減少耦合3、提高內(nèi)聚4、封裝五,性能策略1、同時(shí)計(jì)算7. Architecture根據(jù)軟件的重要需求,確定了本軟件所采用的設(shè)計(jì)模式:
13、7.1 WebService決定運(yùn)用該模式的需求:(1)客戶端數(shù)據(jù)庫與服務(wù)器同步,采用雙數(shù)據(jù)庫實(shí)現(xiàn)效率提高。(2)需調(diào)用API,進(jìn)行每日運(yùn)勢(shì)分析。WebService 調(diào)用每日星座運(yùn)勢(shì)API核心代碼如下:private void updateEverydayFortune() if(isNetworkAvailable()/有網(wǎng)絡(luò)就更新/啟動(dòng)更新數(shù)據(jù)線程new Thread(new updateEverydayFortuneRunnable().start();private class updateEverydayFortuneRunnable implements RunnableSimp
14、leDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");String now = simpleDateFormat.format(new Date();SharedPreferences sharedPreferences = MainActivity.this.getSharedPreferences("xzlm",Context.MODE_WORLD_READABLE);Overridepublic void run() /將值取獲,然后保存for(int i=1;i<
15、;=12;i+)/判斷是否要更新String date = sharedPreferences.getString(i+"_date", "NoDate");if(date.equals("NoDate")|!date.equals(now)/需要更新的星座就去更新。sendInfo(i);private StringBuffer json;private void sendInfo(int constellationid) / 發(fā)送http請(qǐng)求URL url = null;HttpURLConnection conn = null;
16、DataOutputStream outputStream = null;BufferedInputStream bufferedInputStream = null;String requestUrl = "String param = "fun=day&id=" + EverydayFortune.httpConstellationNumberconstellationid - 1 + "&format=json"byte entity = param.getBytes();try url = new URL(request
17、Url);conn = (HttpURLConnection) url.openConnection();conn.setConnectTimeout(5000);conn.setDoOutput(true);conn.setUseCaches(false);conn.setRequestMethod("POST");conn.setRequestProperty("Charset", "UTF-8");conn.setRequestProperty("Content-Length", String.valueOf
18、(entity.length);outputStream = new DataOutputStream(conn.getOutputStream();outputStream.write(entity);outputStream.flush();if (conn.getResponseCode() = 200) bufferedInputStream = new BufferedInputStream(conn.getInputStream();byte bf = new byte1024;int i = 0;json = new StringBuffer();while (i = buffe
19、redInputStream.read(bf) != -1) String str = new String(bf, 0, i);json.append(str); catch (MalformedURLException e) e.printStackTrace(); catch (IOException e) e.printStackTrace();if (json != null) / 有數(shù)據(jù)返回,下面解析這些數(shù)據(jù),并保存resolveJSONAndSave(constellationid);/解析回傳的jsonprivate void resolveJSONAndSave(int co
20、nstellationid) JSONArray array;try array = new JSONArray(json.toString();String zhys = array.getJSONObject(0).getString("rank");String aqys = array.getJSONObject(1).getString("rank");String gzzk = array.getJSONObject(2).getString("rank");String lctz = array.getJSONObjec
21、t(3).getString("rank");String jkzs = array.getJSONObject(4).getString("value");String stzs = array.getJSONObject(5).getString("value");String xyys = array.getJSONObject(6).getString("value");String xysz = array.getJSONObject(7).getString("value");Str
22、ing spxz = array.getJSONObject(8).getString("value");String zhgs = array.getJSONObject(9).getString("value");String date = array.getString(11);/保存到sharedPreferencesSharedPreferences sharedPreferences = MainActivity.this.getSharedPreferences("xzlm", Context.MODE_WORLD_WR
23、ITEABLE);Editor editor = sharedPreferences.edit();editor.putString(constellationid+"_zhys", zhys);editor.putString(constellationid+"_aqys", aqys);editor.putString(constellationid+"_gzzk", gzzk);editor.putString(constellationid+"_lctz", lctz);editor.putString(c
24、onstellationid+"_jkzs", jkzs);editor.putString(constellationid+"_stzs", stzs);editor.putString(constellationid+"_xyys", xyys);editor.putString(constellationid+"_xysz", xysz);editor.putString(constellationid+"_spxz", spxz);editor.putString(constellati
25、onid+"_zhgs", zhgs);editor.putString(constellationid+"_date", date);mit(); catch (JSONException e) / TODO Auto-generated catch blocke.printStackTrace();/* * 判斷有沒有網(wǎng)絡(luò) * * return是否有網(wǎng)絡(luò) */private boolean isNetworkAvailable() Context context = getApplicationContext();ConnectivityManage
26、r connectivity = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);if (connectivity != null) NetworkInfo info = connectivity.getAllNetworkInfo();if (info != null) for (int i = 0; i < info.length; i+) if (infoi.getState() = NetworkInfo.State.CONNECTED) return true;return
27、 false;7.2 MVC (Model View Controller)決定運(yùn)用MVC模式的需求:(1)實(shí)現(xiàn)測(cè)試題目選項(xiàng)統(tǒng)計(jì),進(jìn)行測(cè)試結(jié)果分析。MVC核心代碼如下:/Model:/package com.example.service;import java.util.ArrayList;import java.util.List;import java.util.Observable;public class Model extends Observable private List <Integer> mList ;public int get(int idx) retur
28、n mList.get(idx);public void set(int idx) mList.set(idx,1); setChanged(); notifyObservers();public void back(int idx) mList.set(idx,0);setChanged();notifyObservers();public Model()mList = new ArrayList<Integer>(4);mList.add(0);mList.add(0);mList.add(0);mList.add(0);/Controller:/answerGroup.set
29、OnCheckedChangeListener(new OnCheckedChangeListener()Overridepublic void onCheckedChanged(RadioGroup group, int checkedId) / TODO Auto-generated method stubnextBtn.setEnabled(true);switch (group.getCheckedRadioButtonId() case R.id.answerA:model.set(0);model.back(1);model.back(2);model.back(3);break;
30、case R.id.answerB:model.set(1);model.back(0);model.back(2);model.back(3);break;case R.id.answerC:model.set(2);model.back(0);model.back(1);model.back(3);break;case R.id.answerD:model.set(3);model.back(0);model.back(1);model.back(2);break;7.3 Publish/Subscrib決定運(yùn)用“發(fā)布訂閱”模式的需求:(1)測(cè)試題庫需定期更新,并自動(dòng)提示用戶。Publish/Subscrib核心代碼如下:/Publish/Subscribe接口:/public interface ISubscribe void getNewPaper();/個(gè)人訂閱者:/public class PersonalSubscriber implements ISubscribe private String strName;public void setNewsPaperName(String strName)this.strName = strName;public String getNewsPaperName()return strName;Overridepubli
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 溫州市南浦小學(xué)2022年藝術(shù)節(jié)活動(dòng)方案范文
- 環(huán)保教育培養(yǎng)下一代綠色生活意識(shí)
- 現(xiàn)代教育技術(shù)助力創(chuàng)新教學(xué)方法的推廣
- 現(xiàn)代辦公家具中的穩(wěn)固與美觀并存
- 國慶節(jié)成都漢服活動(dòng)方案
- 現(xiàn)代遠(yuǎn)程教育在海外的發(fā)展趨勢(shì)分析
- 汽車行業(yè)的社交媒體廣告投放策略
- 國慶節(jié)旅游宣傳活動(dòng)方案
- 溫控技術(shù)在綠色辦公樓宇的革新發(fā)展
- 現(xiàn)代建筑設(shè)計(jì)的情感化表達(dá)
- 在馬克思墓前的講話說課稿公開課一等獎(jiǎng)市賽課獲獎(jiǎng)?wù)n件
- 骨科無痛病房的建立
- 送養(yǎng)收養(yǎng)合同協(xié)議書
- 塑料成型模具設(shè)計(jì)(第2版)江昌勇課件0-導(dǎo)論
- 漢語拼音發(fā)音口型及配圖
- 五年級(jí)下冊(cè)《Lesson 11 Shopping in Beijing》教案冀教版三年級(jí)起點(diǎn)小學(xué)英語-五年級(jí)英語教案
- 績效考核管理醫(yī)院績效分配方案包括實(shí)施細(xì)則考核表
- 大學(xué)成績單(大專)
- 網(wǎng)絡(luò)設(shè)備安裝與調(diào)試(華為eNSP模擬器)整套教學(xué)課件
- GB/T 15234-1994塑料平托盤
- 教科版科學(xué)五年級(jí)下冊(cè)《生物與環(huán)境》單元教材解讀及教學(xué)建議
評(píng)論
0/150
提交評(píng)論