鄭州大學需求規(guī)格說明_第1頁
鄭州大學需求規(guī)格說明_第2頁
鄭州大學需求規(guī)格說明_第3頁
鄭州大學需求規(guī)格說明_第4頁
鄭州大學需求規(guī)格說明_第5頁
已閱讀5頁,還剩70頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、1Software Requirements Engineering軟件需求工程 鄭州大學軟件學院 軟件工程專業(yè)必修課程授課對象:本科3年級授課教師:徐強22 Requirements Specification需求規(guī)格說明 33軟件需求規(guī)格說明編寫需求文檔的原則需求示例改進前后質量屬性軟件需求規(guī)格說明模板本章內容44SRS Document軟件需求規(guī)格說明55可以用三種方法編寫軟件需求規(guī)格說明:用好的結構化的自然語言編寫文本型文檔。建立圖形化模型,這些模型可以描繪轉換過程、系統(tǒng)狀態(tài)和它們之間的變化、數(shù)據關系、邏輯流或對象類和它們的關系。編寫形式化規(guī)格說明,這可以通過使用數(shù)學上精確的形式化邏輯

2、語言來定義需求。編寫軟件需求規(guī)格說明66雖然結構化的自然語言具有許多缺點,但在大多數(shù)軟件工程中,它仍是編寫需求文檔最現(xiàn)實的方法。包含了功能和非功能需求的基于文本的軟件需求規(guī)格說明已經為大多數(shù)項目所接受。圖形化分析模型通過提供另一種需求視圖,增強了軟件需求規(guī)格說明。由于形式化規(guī)格說明具有很強的嚴密性和精確度,因此,所使用的形式化語言只有極少數(shù)軟件開發(fā)人員才熟悉,更不用說客戶了。編寫軟件需求規(guī)格說明77關于SRS軟件需求規(guī)格說明,也稱為功能規(guī)格說明、需求協(xié)議以及系統(tǒng)規(guī)格說明。它精確地闡述一個軟件系統(tǒng)必須提供的功能和性能以及它所要考慮的限制條件。軟件需求規(guī)格說明不僅是系統(tǒng)測試和用戶文檔的基礎,也是所

3、有子系列項目規(guī)劃、設計和編碼的基礎。它應該盡可能完整地描述系統(tǒng)預期的外部行為和用戶可視化行為。除了設計和實現(xiàn)上的限制,軟件需求規(guī)格說明不應該包括設計、構造、測試或工程管理的細節(jié)。88關于SRS軟件需求規(guī)格說明作為產品需求的最終成果必須具有綜合性:必須包括所有的需求。開發(fā)者和客戶不能作任何假設。如果任何所期望的功能或非功能需求未寫入軟件需求規(guī)格說明,那么它將不能作為協(xié)議的一部分并且不能在產品中出現(xiàn)。毫無疑問,必須在開始設計和構造之前編寫出整個產品的軟件需求規(guī)格說明。可以反復地或以漸增方式編寫需求規(guī)格說明。99SRS的閱讀者不同人員使用軟件需求規(guī)格說明來達到不同的目的:客戶和營銷部門依賴它來了解他

4、們所能提供的產品。項目經理根據包含在軟件需求規(guī)格說明中描述的產品來制定規(guī)劃并預測進度安排、工作量和資源。軟件開發(fā)小組依賴它來理解他們將要開發(fā)的產品。測試小組使用軟件需求規(guī)格說明中對產品行為的描述制定測試計劃、測試用例和試過程。軟件維護和支持人員根據SRS了解產品的某部分是做什么的。產品發(fā)布組在SRS和用戶界面設計的基礎上編寫客戶文檔,如用戶手冊和幫助屏幕等。培訓人員根據SRS和用戶文檔編寫培訓材料。1010SRS的可讀性可讀性的建議:對節(jié)、小節(jié)和單個需求的號碼編排必須一致。右邊部分留下文本注釋區(qū)。允許不加限制地使用空格。正確使用各種可視化強調標志(例如,黑體、下劃線、斜體和其它不同字體)。創(chuàng)建

5、目錄表和索引表有助于讀者尋找所需的信息。對所有圖和表指定號碼和標識號,并且可按號碼進行查閱。使用字處理程序中交叉引用的功能來查閱文檔中其它項或位置,而不是通過頁碼或節(jié)號。1111標識需求為了滿足軟件需求規(guī)格說明的可跟蹤性和可修改性的質量標準,必須唯一確定每個軟件需求。這可以在變更請求、修改歷史記錄、交叉引用或需求的可跟蹤矩陣中查閱特定的需求。由于要達到這一目的,用單一的項目列表是不夠的,因此,描述幾個不同的需求標識方法,并闡明它們的優(yōu)點與缺點。可以根據情況選擇最適合的方法。1212Identifying requirements 標識需求1) 序列號 最簡單的方法是賦予每個需求一個唯一的序列號

6、,例如UR-2或SRS13。當一個新的需求加入到商業(yè)需求管理工具的數(shù)據庫之后,這些管理工具就會為其分配一個序列號(許多這樣的工具也支持層次化編號)。序列號的前綴代表了需求類型,例如UR代表“用戶需求”。由于序列號不能重用,所以把需求從數(shù)據庫中刪除時,并不釋放其所占據的序列號,而新的需求只能得到下一個可用的序列號。這種簡單的編號方法并不能提供任何相關需求在邏輯上或層次上的區(qū)別,而且需求的標識不能提供任何有關每個需求內容的信息。1313Identifying requirements 標識需求2) 層次化編碼 這也許是最常用的方法。如果功能需求出現(xiàn)在軟件需求規(guī)格說明中第3.2部分,那么它們將具有諸

7、如這樣的標識號。標識號中的數(shù)字越多則表示該需求越詳細,屬于較低層次上的需求。這種方法簡單且緊湊,(字處理程序可能可以自動編排序號)。然而,即使在一個中型的軟件需求規(guī)格說明中,這些標識號也會擴展到許多位數(shù)字,并且這些標識也不提供任何有關每個需求目的的信息。如果要插入一個新的需求,那么該需求所在部分其后所有需求的序號將要增加。刪除或移去一個需求,那么該需求所在部分其后所有需求的序號將要減少。這些變化將破壞系統(tǒng)其它地方需求的引用。1414Identifying requirements 標識需求2) 層次化編碼 (contd.)對于這種簡單的層次化編號的一種改進方法是對需求中主要的部分進行層次化編號

8、,然后對于每個部分中的單一功能需求用一個簡短文字代碼加上一個序列號來識別。例如,軟件需求規(guī)格說明可能包含“第3.2.5部分編輯功能”,那么這一部分需求的編號可以寫成ED-1、ED-2等等。這種方法具有層次性和組織性,同時使標識號簡短和具有一定意義并與位置無關等特點。如果要在ED-1和ED-2之間插入新的需求ED-9,則不必對該部分中余下的需求重新編號。1515Identifying requirements 標識需求 3) 層次化文本標簽基于文本的層次化標簽方案來標識單個需求(Gilb 1988)??紤]這樣一個需求:“當用戶請求打印超過10個副本時,系統(tǒng)必須讓用戶進行確認判斷?!边@一需求可能被

9、標識為“打印.副本.確認”,這意味著這個需求是打印功能的一部分,并且與要打印的副本數(shù)量的設置問題有關。層次化文本標簽是結構化的,具有語義上的含義,并且不受增加、刪除或移動其它需求的影響。它們的主要缺點是文本標簽比層次化數(shù)字標識碼復雜。1616處理不完整性有時會缺少特定需求的某些信息。在解決這個不確定性之前,可能必須與客戶商議、檢查與另一個系統(tǒng)的接口或者定義另一個需求。使用“待確定”(to be determined, TBD)符號作為標準指示器來強調軟件需求規(guī)格說明中這些需求的缺陷(gap)。通過這種方法,可以在軟件需求規(guī)格說明中查找所要澄清需求的部分。記錄誰將解決哪個問題、怎樣解決及什么時候

10、解決。把每個TBD編號并創(chuàng)建一個TBD列表,這有助于方便地跟蹤每個項目。在繼續(xù)進行構造需求集合之前,必須解決所有的TBD問題,因為任何遺留下來的不確定問題將會增加出錯的風險和需求返工。當開發(fā)人員遇到一個TBD問題或其它模糊之處時,他可能不會返回到原始需求來解決問題。多半開發(fā)者對它進行猜測,但并不總是正確的。如果有TBD問題尚未解決,而又要繼續(xù)進行開發(fā)工作,那么盡可能推遲實現(xiàn)這些需求,或者解決這些需求的開放式問題,把產品的這部分設計得易于更改。1717關于用戶界面把用戶界面的設計編入軟件需求規(guī)格說明既有好處也有壞處。Disadvantage 消極方面,屏幕映像和用戶界面機制是解決方案(設計)的描

11、述,而不是需求。如果在完成了用戶界面的設計之后才能確定軟件需求規(guī)格說明,那么需求開發(fā)的過程將會花費很長的時間。這將會使那些只關心需求開發(fā)時間的經理、客戶或開發(fā)人員失去耐心。用戶界面的布局不能替代定義功能需求。不要指望開發(fā)人員可以從屏幕中推斷出潛在的功能和數(shù)據關系。把用戶界面的設計加入軟件需求規(guī)格說明還意味著開發(fā)人員在更改一個用戶界面的元素時必須相應更改需求的過程。1818關于用戶界面Advantage 積極方面,探索潛在的用戶界面有助于精化需求并使 用戶系統(tǒng) 的交互對用戶和開發(fā)人員更具有實在性。用戶界面的演示也有助于項目計劃的制定和預測。根據以往類似開發(fā)活動的經驗,可以數(shù)清圖形用戶界面(GUI

12、)的元素數(shù)目或者計算與每個屏幕有關的功能點數(shù)目,然后估計實現(xiàn)這些屏幕功能所需的工作量。1919權衡點一個合理的權衡點是:在軟件需求規(guī)格說明中加入所選擇的用戶界面組件的概念映像草圖,而在實現(xiàn)時并不一定要精確地遵循這些方法。通過使用另一種方式來表示需求,從而增強相互交流的能力,但并不增加對開發(fā)人員的限制,也不增加變更管理過程的負擔。例如,一個復雜對話框的最初草案將描述支持需求部分的意圖,但是一個有經驗的設計者可以把它轉化為一個帶有標簽組件的對話框或使用其它方法以提高其可用性。2020需求文檔模板 每個軟件開發(fā)組織都應該在它們的項目中采用一種標準的軟件需求規(guī)格說明的模板。許多人使用來自IEEE標準8

13、30-1998的模板,“IEEE推薦的軟件需求規(guī)格說明的方法” (IEEE 1998) 。GB8567-88模板GBT9385-2008計算機軟件需求規(guī)格說明規(guī)范2121軟件需求規(guī)格說明編寫需求文檔的原則需求示例改進前后質量屬性軟件需求規(guī)格說明模板本章內容2222Principle of SRS編寫需求文檔的原則2323需求文檔的原則編寫優(yōu)秀的需求文檔沒有現(xiàn)成固定的方法,最好是根據經驗進行。從過去所遇到的問題中可使你受益匪淺。在編寫軟件需求文檔時,應牢記以下幾點建議:保持語句和段落的簡短。采用主動語態(tài)的表達方式。編寫具有正確的語法、拼寫和標點的完整句子。使用的術語與詞匯表中所定義的應該一致。2

14、424需求文檔的原則需求陳述應該具有一致的樣式,例如“系統(tǒng)必須”或者“用戶必須”,并緊跟一個行為動作和可觀察的結果。例如,“倉庫管理子系統(tǒng)必須顯示一張所請求的倉庫中有存貨的化學藥品容器清單?!睘榱藴p少不確定性,必須避免模糊的、主觀的術語,例如,用戶友好、容易、簡單、迅速、有效、支持、許多、最新技術、優(yōu)越的、可接受的和健壯的。當用客說“用戶友好”或者“快”或者“健壯”時,你應該明確它們的真正含義并且在需求中闡明用戶的意圖。避免使用比較性的詞匯,例如:提高、最大化、最小化和最佳化。定量地說明所需要提高的程度或者說清一些參數(shù)可接受的最大值和最小值。當客戶說明系統(tǒng)應該“處理”、“支持”或“管理”某些事

15、情時,你應該能理解客戶的意圖。含糊的語句表達將引起需求的不可驗證。2525細節(jié)由于需求的編寫是層次化的,因此,可以把頂層不明確的需求向低層詳細分解,直到消除不明確性為止。編寫詳細的需求文檔,所帶來的益處是如果需求得到滿足,那么客戶的目的也就達到了,但是不要讓過于詳細的需求影響了設計。2626方針文檔的編寫人員必須以相同的詳細程度編寫每個需求文檔。文檔的編寫人員不應該把多個需求集中在一個冗長的敘述段落中。在需求中諸如“和”,“或”之類的連詞就表明了該部分集中了多個需求。務必記住,不要在需求說明中使用“和/或”,“等等”之類的連詞。文檔的編寫人員在編寫軟件需求規(guī)格說明時不應該出現(xiàn)需求冗余。雖然在不

16、同的地方出現(xiàn)相同的需求可能會使文檔更易讀,但這也造成了維護上的困難。需求的多個實例都需要同時更新,以免造成需求各實例之間的不一致。文檔的編寫人員應考慮用最有效的方法表達每個需求。2727軟件需求規(guī)格說明編寫需求文檔的原則需求示例改進前后質量屬性軟件需求規(guī)格說明模板本章內容2828需求示例改進前后2929Example 1“產品必須在固定的時間間隔內提供狀態(tài)消息,并且每次時間間隔不得小于60秒”。這個需求看起來是不完整的:什么是狀態(tài)消息,并且在什么情況下向用戶提供這些消息?顯示時間多長?我們所說的是產品的哪一部分?時間間隔也會導致混淆。假定顯示狀態(tài)消息之間的時間間隔只要求不少于60秒,按這樣推理

17、,是否可以每隔一年顯示一次狀態(tài)信息?如果意圖是消息之間的時間間隔不多于60秒,那么1毫秒會不會太短?消息顯示的時間間隔怎樣才能一致?“每次”這個詞混淆了這一問題。由于這些問題的存在,導致了需求是不可驗證的。3030Example 1(contd.)這里提出一個方法使我們能重寫需求文檔來表述這些缺點(從我們與客戶一致的目標出發(fā)作出一些猜測)即:后臺任務管理器(BTM)應該在用戶界面的指定區(qū)域顯示狀態(tài)消息。a. 在后臺任務進程啟動之后,消息必須每隔60(10)秒更新一次,并且保持連續(xù)的可見性。b. 如果正在正常處理后臺任務進程,那么后臺任務管理器(BTM)必須顯示后臺任務進程已完成的百分比。c.

18、當完成后臺任務時,后臺任務管理器(BTM)必須顯示一個“已完成”的消息。d. 如果后臺任務中止執(zhí)行,那么后臺任務管理器(BTM)必須顯示一個出錯消息。3131Example 1(contd.)把原先的需求分割成多個需求,因為每個需求都需要獨立的測試用例并且使各個需求都具有可跟蹤性。如果把多個需求都集中在一個段落中,那么在構造軟件和測試時就很容易忽略其中某個需求。注意,修改之后的需求并沒有精確地說明是怎樣顯示狀態(tài)信息的。這是一個設計問題,如果你在這個地方詳述該問題,那么就會給開發(fā)人員帶來設計上的一些限制。過早地限制設計上的可選方案將會給編程人員帶來不利因素,并可導致產品設計的失敗。3232Exa

19、mple 2“產品必須在顯示和隱藏非打印字符之間進行瞬間切換”。在瞬間這一時間概念上,計算機不能完成任何工作,因此,這個需求是不可行的。該需求也是不完整的,因為它沒有說清狀態(tài)切換的原因。在特定的條件下,軟件產品是否可以進行自動切換或者可否由用戶采取某些措施來激發(fā)這樣轉變?還有,在文檔中顯示轉變的范圍是什么?是所選的文本、整個文檔或其它內容?這個需求也存在一個不確定性問題?!胺谴蛴 弊址欠裰鸽[藏文本、屬性標記或者其它的控制字符?由于存在這些問題,該需求是不可驗證的。3333Example 2(contd.)用如下的語句描述這個需求可能會更好一些:“用戶在編輯文檔時,通過激活特定的觸發(fā)機制,可以

20、在顯示和隱藏所有HTML標記之間進行切換”。現(xiàn)在,指代關系就清楚了,非打印字符指的是HTML標記。修改過的需求指明了是用戶觸發(fā)了顯示狀態(tài)的轉換,但是它并沒有對設計造成限制,因為它并沒有精確定義所使用的機制。當設計人員選擇好一種觸發(fā)機制(例如熱鍵、菜單命令或語音輸入)時,你就可以編寫詳細的測試用例來驗證這種轉換操作是否正確。3434Example 3“分析程序應該能生成HTML標記出錯的報告,這樣就可以使HTML的初學者使用它來迅速排錯?!薄把杆佟边@個詞具有模糊性。缺乏對出錯報告內容的定義表明該需求是不完整的。是如何驗證這個需求的?找一些HTML的初學者,看他們利用這個報告是否可以迅速排錯?還有

21、一點不清楚的是:HTML初學者使用的是分析程序還是出錯報告。并且何時生成這樣的報告?3535Example 3(contd.)讓我們使用另一種方式表述這個需求:a. 在HTML分析程序完全分析完一個文件后,該分析程序必須生成一個出錯報告,這個報告中包含了在分析文件過程中所發(fā)現(xiàn)錯誤的HTML所在的行號以及文本內容,還包含了對每個錯誤的描述。b. 如果在分析過程中未發(fā)現(xiàn)任何錯誤,就不必生成出錯報告?,F(xiàn)在我們知道了任何生成出錯報告及其所包含的內容,但是我們已經把該需求提交給設計人員,讓他們來決定報告的形式。我們還指明了一種例外情況:如果沒有任何錯誤,就不生成出錯報告。3636Example 4“如果

22、可能的話,應當根據主貨物編號列表在線確認所輸入的貨物編號。”“如果可能的話”這句話意味著什么?該需求是否在技術上可行?是否可以在線訪問主貨物編號列表?如果你不能確信是否可以遞交一個請求,那么就使用“待確定” ( TBD )來表示未解決的問題。這個需求是不完整的,因為它并沒有指明如果確認通過或失敗,將會發(fā)生什么情況。應該盡量避免使用不精確的詞匯,例如“應當”??蛻艨赡苄枰@個功能或者不需要這個功能。一些需求規(guī)格說明利用關鍵字之間微妙的差別如“應當”,“必須”和“可能”來指明重要性。一些人更喜歡使用“必須”或“將要”來明確說明需求的目的并且明確指定其優(yōu)先級。3737Example 4(contd.

23、)改進后的該需求描述如下:“系統(tǒng)必須根據在線的主貨物編號列表確認所輸入的貨物編號。如果在主列表中查不到該貨物的編號,系統(tǒng)必須顯示一個出錯消息并且拒絕訂貨。”第二種相關需求可能記錄了一種異常情況:當進行貨物編號確認時,主貨物編號列表不可訪問。3838Example 5“產品不應該提供將帶來災難性后果的查詢和替換選擇。”“災難性后果”的含義是解釋的中心詞。在編輯文檔時,毫無目的地作出全局性變化而用戶又不能檢測出錯誤或沒有任何辦法來糾正它,此時就可能帶來災難性后果。也要合理地使用反面需求,因為這些需求描述了系統(tǒng)所不能做的事情。潛在的關注焦點在于當發(fā)生意外損壞時,能保護文件的內容。也許,真正的需求是針

24、對多級撤銷( undo )能力、全局變化或其它可導致數(shù)據丟失行為確定的。3939軟件需求規(guī)格說明編寫需求文檔的原則需求示例改進前后質量屬性軟件需求規(guī)格說明模板本章內容4040Quality Attribute質量屬性4141質量屬性(非功能屬性)用戶對產品如何良好地運轉抱有許多期望。這些特性包括:產品的易用程度如何,執(zhí)行速度如何,可靠性如何,當發(fā)生異常情況時,系統(tǒng)如何處理。這些被稱為軟件質量屬性(或質量因素)的特性是系統(tǒng)非功能(也叫非行為)部分的需求。Quality Attribute(質量屬性)是很難定義的,并且他們經常造成開發(fā)者設計的產品和客戶滿意的產品之間的差異。“真正的現(xiàn)實系統(tǒng)中,在決

25、定系統(tǒng)的成功或失敗的因素中,滿足非功能需求往往比滿足功能需求更為重要”。 -Robert Charette(1990) 4242質量屬性雖然有許多產品特性可以稱為質量屬性(Quality Attribute),但是在許多系統(tǒng)中需要認真考慮的僅是其中的一小部分。如果開發(fā)者知道哪些特性對項目的成功至關重要,那么他們就能選擇軟件工程方法來達到特定的質量目標。 ( Glass 1992; DeGrace and Stahl 1993)。根據不同的設計可以把質量屬性分類。 ( Boehm 1976; DeGrace and Stahl 1993)。一種屬性分類的方法是把在運行時可識別的特性與那些不可識別

26、的特性區(qū)分開( Bass, Clements and Kazman 1998)。另一種方法是把對用戶很重要的可見特性與對開發(fā)者和維護者很重要的不可見特性區(qū)分開。那些對開發(fā)者具有重要意義的屬性使產品易于更改、驗證,并易于移植到新的平臺上,從而可以間接地滿足客戶的需要。4343質量屬性ISO/IEC 9126將軟件的質量分為六個特征:4444軟件質量屬性4545定義質量屬性必須根據用戶對系統(tǒng)的期望來確定質量屬性。定量地確定重要屬性提供了對用戶期望的清晰理解,這將有助于設計者提出最合理的解決方案。-Gilb 1988然而,大多數(shù)用戶并不知道如何回答諸如“互操作性對你的重要性如何?”或者“軟件應該具有

27、怎樣的可靠性?”等問題。在一個項目中,分析員想出了對于不同的用戶類可能很重要的屬性,并根據每一個屬性設計出許多問題。他們利用這些問題詢問每一個用戶類的代表,可以把每個屬性分成一級(不必多加考慮的屬性)到五級(極其重要的屬性)。這些問題的回答有助于分析員決定哪些質量特性用作設計標準是最重要的。4646定義質量屬性然后,分析員與用戶一起為每一屬性確定特定的、可測量的和可驗證的需求(Robertson 1997)。如果質量目標不可驗證,那么就說不清是否達到這些目標。在合適的地方為每一個屬性或目標指定級別或測量單位,以及最大和最小值。如果不能定量地確定某些對你的項目很重要的屬性,那么至少應該確定其優(yōu)先

28、級。IEEE關于軟件質量度量方法的標準提出了一個在綜合質量度量基準體系下定義軟件質量需求的方法( IEEE 1992)4747定義質量屬性另一個定義屬性的方法是確定任何與質量期望相沖突的系統(tǒng)行為( Voas 1999)。通過定義不悅人意行為一種反向需求可以設計出強制系統(tǒng)表現(xiàn)出那些行為的測試用例。如果不能強制系統(tǒng),那么可能達到了屬性目標。這種方法最適用于要求安全性能很高的應用程序,在這些應用程序中,系統(tǒng)的差錯可能會導致生命危險。4848對用戶重要的屬性Availability 有效性 有效性指的是在預定的啟動時間中,系統(tǒng)真正可用并且完全運行時間所占的百分比。更正式地說,有效性等于系統(tǒng)的平均故障時

29、間(MTTF)除以平均故障時間與故障修復時間之和。有些任務比起其它任務具有更嚴格的時間要求,此時,當用戶要執(zhí)行一個任務但系統(tǒng)在那一時刻不可用時,用戶會感到很沮喪。詢問用戶需要多高的有效性,并且是否在任何時間,對滿足業(yè)務或安全目標有效性都是必須的。一個有效性需求可能這樣說明:“工作日期間,在當?shù)貢r間早上6點到午夜,系統(tǒng)的有效性至少達到99.5 %,在下午4點到6點,系統(tǒng)的有效性至少可達到99.95%。4949對用戶重要的屬性2) Efficiency 效率效率是用來衡量系統(tǒng)如何優(yōu)化處理器、磁盤空間或通信帶寬的( Davis 1993)。如果系統(tǒng)用完了所有可用的資源,那么用戶遇到的將是性能的下降,

30、這是效率降低的一個表現(xiàn)。拙劣的系統(tǒng)性能可激怒等待數(shù)據庫查詢結果的用戶,或者可能對系統(tǒng)安全性造成威脅,就像一個實時處理系統(tǒng)超負荷一樣。為了在不可預料的條件下允許安全緩沖,可以這樣定義:“在預計的高峰負載條件下, 10%處理器能力和15%系統(tǒng)可用內存必須留出備用?!痹诙x性能、能力和效率目標時,考慮硬件的最小配置是很重要的。5050對用戶重要的屬性3) Flexibility 靈活性就像我們所知道的可擴充性、增加性、可延伸性和可擴展性一樣,靈活性表明了在產品中增加新功能時所需工作量的大小。如果開發(fā)者預料到系統(tǒng)的擴展性,那么他們可以選擇合適的方法來最大限度地增大系統(tǒng)的靈活性。靈活性對于通過一系列連續(xù)

31、的發(fā)行版本,并采用漸增型和重復型方式開發(fā)的產品是很重要的。example:“一個至少具有6個月產品支持經驗的軟件維護程序員可以在一個小時之內為系統(tǒng)添加一個新的可支持硬拷貝的輸出設備。”5151對用戶重要的屬性4) Integrity 完整性完整性(或安全性)主要涉及:防止非法訪問系統(tǒng)功能、防止數(shù)據丟失、防止病毒入侵并防止私人數(shù)據進入系統(tǒng)。完整性對于通過WWW執(zhí)行的軟件已成為一個重要的議題。電子商務系統(tǒng)的用戶關心的是保護信用卡信息, Web的瀏覽者不愿意那些私人信息或他們所訪問過的站點記錄被非法使用。完整性的需求不能犯任何錯誤,即數(shù)據和訪問必須通過特定的方法完全保護起來。用明確的術語陳述完整性的

32、需求,如身份驗證、用戶特權級別、訪問約束或者需要保護的精確數(shù)據。一個完整性的需求樣本可以這樣描述:“只有擁有查賬員訪問特權的用戶才可以查看客戶交易歷史?!?252對用戶重要的屬性5) Interoperability 互操作性互操作性表明了產品與其它系統(tǒng)交換數(shù)據和服務的難易程度。為了評估互操作性是否達到要求的程度,必須知道用戶使用其它哪一種應用程序與產品相連接,還要知道他們要交換什么數(shù)據。example:“化學制品跟蹤系統(tǒng)應該能夠從ChemiDraw和Chem-Struct工具中導入任何有效化學制品結構圖?!?353對用戶重要的屬性6) Reliability 可靠性可靠性是軟件無故障執(zhí)行一段

33、時間的概率(Musa, Iannino and Okumoto 1987)。健壯性和有效性有時可看成是可靠性的一部分。衡量軟件可靠性的方法包括正確執(zhí)行操作所占的比例,在發(fā)現(xiàn)新缺陷之前系統(tǒng)運行的時間長度和缺陷出現(xiàn)的密度。根據如果發(fā)生故障對系統(tǒng)有多大影響和對于最大的可靠性的費用是否合理,來定量地確定可靠性需求。如果軟件滿足了它的可靠性需求,那么即使該軟件還存在缺陷,也可認為達到其可靠性目標。要求高可靠性的系統(tǒng)也是為高可測試性系統(tǒng)設計的。Example:“由于軟件失效引起實驗失敗的概率應不超過5”。5454對用戶重要的屬性7) Robustness 健壯性健壯性指的是當系統(tǒng)或其組成部分遇到非法輸入數(shù)

34、據、相關軟件或硬件組成部分的缺陷或異常的操作情況時,能繼續(xù)正確運行功能的程度。健壯的軟件可以從發(fā)生問題的環(huán)境中完好地恢復并且可容忍用戶的錯誤。當從用戶那里獲取健壯性的目標時,詢問系統(tǒng)可能遇到的錯誤條件并且要了解用戶想讓系統(tǒng)如何響應。“所有的規(guī)劃參數(shù)都要指定一個缺省值,當輸入數(shù)據丟失或無效時,就使用缺省值數(shù)據?!边@個例子反映了對一個“用戶”是另一個軟件應用程序的產品,其健壯性設計的方法。5555對用戶重要的屬性8) Usability 可用性可用性也稱為“易用性”和“人類工程”,它所描述的是許多組成“用戶友好”的因素??捎眯院饬繙蕚漭斎?、操作和理解產品輸出所花費的努力。必須權衡易用性和學習如何操

35、縱產品的簡易性。對于可用性的討論可以得出可測量的目標,例如:一個培訓過的用戶應該可以在平均3分鐘或最多5分鐘時間以內,完成從供應商目錄表中請求一種化學制品的操作??捎眯赃€包括對于新用戶或不常使用產品的用戶在學習使用產品時的簡易程度。易學程度的目標可以經常定量地測量。例如,“一個新用戶用不到3 0分鐘時間適應環(huán)境后,就應該可以對一個化學制品提出請求”,或者“新的操作員在一天的培訓學習之后,就應該可以正確執(zhí)行他們所要求的任務的95%”。當定義可用性或可學性的需求時,應考慮到在判斷產品是否達到需求而對產品進行測試的費用。5656對開發(fā)者重要的屬性Maintainability 可維護性可維護性表明了

36、在軟件中糾正一個缺陷或做一次更改的簡易程度。可維護性取決于理解軟件、更改軟件和測試軟件的簡易程度,可維護性與靈活性密切相關。高可維護性對于那些經歷周期性更改的產品或快速開發(fā)的產品很重要??梢愿鶕迯停╢ix)一個問題所花的平均時間和修復正確的百分比來衡量可維護性。Example:“函數(shù)調用不能超過兩層深度“,并且“每一個軟件模塊中,注釋與源代碼語句的比例至少為12”。5757對開發(fā)者重要的屬性2) Portability 可移植性可移植性是度量把一個軟件從一種運行環(huán)境轉移到另一種運行環(huán)境中所花費的工作量。軟件可移植的設計方法與軟件可重用的設計方法相似( Glass 1992)??梢浦残詫τ诠こ?/p>

37、的成功是不重要的,對工程的結果也無關緊要。可以移植的目標必須陳述產品中可以移植到其它環(huán)境的那一部分,并確定相應的目標環(huán)境。于是,開發(fā)者就能選擇設計和編碼方法以適當提高產品的可移植性。5858對開發(fā)者重要的屬性3) Reusability 可重用性從軟件開發(fā)的長遠目標上看,可重用性表明了一個軟件組件除了在最初開發(fā)的系統(tǒng)中使用之外,還可以在其它應用程序中使用的程度。比起創(chuàng)建一個打算只在一個應用程序中使用的組件,開發(fā)可重用軟件的費用會更大些??芍赜密浖仨殬藴驶?、資料齊全、不依賴于特定的應用程序和運行環(huán)境,并具有一般性( DeGrace and Stahl 1993)。確定新系統(tǒng)中哪些元素需要用方便

38、于代碼重用的方法設計,或者規(guī)定作為項目副產品的可重用性組件庫。5959對開發(fā)者重要的屬性4) Testability 可測試性可測試性指的是測試軟件組件或集成產品時查找缺陷的簡易程度。如果產品中包含復雜的算法和邏輯,或如果具有復雜的功能性的相互關系,那么對于可測試性的設計就很重要。如果經常更改產品,那么可測試性也是很重要的,因為將經常對產品進行回歸測試來判斷更改是否破壞了現(xiàn)有的功能性。example:“一個模塊的最大循環(huán)復雜度不能超過20”。循環(huán)復雜度度量一個模塊源代碼中邏輯分支數(shù)目(McCabe 1982)。在一個模塊中加入過多的分支和循環(huán)將使該模塊難于測試、理解和維護。如果一些模塊的循環(huán)復

39、雜度大于2 0,這并不會導致整個項目的失敗,但指定這樣的設計標準有助于開發(fā)者達到一個令人滿意的質量目標。6060屬性的取舍用戶和開發(fā)者必須確定哪些屬性比其它屬性更為重要,并定出優(yōu)先級。在他們作決策時,要始終遵照那些優(yōu)先級。6161選擇的質量屬性之間的正負關系有效性效率靈活性完整性互操作性可維護性可移植性可靠性可重用性健壯性可測試性可用性6262平衡性一個單元格中的加號表明單元格所在行的屬性增加了對其所在列的屬性的積極影響。例如,增強軟件可重用性的設計方法也可以使軟件變得靈活、更易于與其它軟件組件相連接、更易于維護、更易于移植并且更易于測試。一個單元格中的減號表明單元格所在行的屬性增加了對其所在

40、列的屬性的不利影響。高效性對其它許多屬性具有消極影響。如果你編寫最緊湊,最快的代碼,并使用一種特殊的預編譯器和操作系統(tǒng),那么這將不易移植到其它環(huán)境,而且還難于維護和改進軟件。6363平衡性為了達到產品特性的最佳平衡,必須在需求獲取階段識別、確定相關的質量屬性,并且為之確定優(yōu)先級。當為項目定義重要的質量屬性時,利用上圖可以防止發(fā)生與目標沖突的行為。在軟件中,其自身不能實現(xiàn)質量特性的合理平衡。在需求獲取的過程中,加入對質量屬性期望的討論,并把所了解的寫入軟件需求規(guī)格說明中。這樣,才有可能提供使所有項目風險承擔者滿意的產品。6464軟件需求規(guī)格說明編寫需求文檔的原則需求示例改進前后質量屬性軟件需求規(guī)

41、格說明模板本章內容軟件需求規(guī)格說明模板a. 引言 a.1 目的 a.2 文檔約定 a.3 預期的讀者和閱讀建議 a.4 產品的范圍 a.5 參考文獻b. 綜合描述 b.1 產品的前景 b.2 產品的功能 b.3 用戶類和特征 b.4 運行環(huán)境 b.5 設計和實現(xiàn)上的限制 b.6 假設和依賴C. 外部接口需求 C.1 用戶界面 C.2 硬件接口 C.3 軟件接口 C.4 通信接口d. 系統(tǒng)特性 d.1 說明和優(yōu)先級 d.2 激勵響應序列 d.3 功能需求e. 其它非功能需求 e.1 性能需求 e.2 安全設施需求 e.3 安全性需求 e.4 軟件質量屬性 e.5 業(yè)務規(guī)則 e.6 用戶文檔f.

42、其它需求附錄A:詞匯表附錄B:分析模型附錄C:待確定問題的列表從IEEE 830標準改寫并擴充的軟件需求規(guī)格說明的模板 需求規(guī)格說明模板-引言 a. 引言引言提出了對軟件需求規(guī)格說明的縱覽,這有助于讀者理解文檔如何編寫并且如何閱讀和解釋。a.1 目的對產品進行定義,在該文檔中詳盡說明了這個產品的軟件需求,包括修正或發(fā)行版本號。如果這個軟件需求規(guī)格說明只與整個系統(tǒng)的一部分有關系,那么只定義文檔中說明的部分或子系統(tǒng)。a.2 文檔約定描述編寫文檔時所采用的標準或排版約定,包括正文風格、提示區(qū)或重要符號。列如,說明了高層需求的優(yōu)先級是否可以被其所有細化的需求繼承,或者每個需求陳述是否都有其自身的優(yōu)先級

43、。 需求規(guī)格說明模板-引言 a.3 預期的讀者和閱讀建議列舉了軟件需求規(guī)格說明所針對的不同讀者,列如開發(fā)人員、項目經理、營銷人員、用戶、測試人員或文檔的編寫人員。描述了文檔中剩余部分的內容及其組織結構。提出了最適合于每一類型讀者閱讀文檔的建議。a.4 產品的范圍提供了對指定的軟件及其目的的簡短描述,包括利益和目標。把軟件與企業(yè)目標或業(yè)務策略相聯(lián)系??梢詤⒖柬椖恳晥D和范圍文檔而不是將其內容復制到這里。a.5 參考文獻列舉了編寫軟件需求規(guī)格說明時所參考的資料或其它資源。這可能包括用戶界面風格指導、合同、標準、系統(tǒng)需求規(guī)格說明、使用實例文檔,或相關產品的軟件需求規(guī)格說明。在這里應該給出詳細的信息,包括標題名稱、作者、版本號、日期、出版單位或資料來源,以方便讀者查閱這些文獻。 需求規(guī)格說明模板-綜合描述 b.綜合描述這一部分概述了正在定義的產品以及它所運行的環(huán)境、使用產品的用戶和已知的限制、假設和依賴。b.1 產品的前景描述了軟件需求規(guī)格說明中所定義的產品的背景和起源。 b.2 產品的功能概述了產品所具有的主要功能。其詳細內容將在d中描述,所以在此只需要概略地總結,例如用列表的方法給出。b.3 用戶類和特征確定你覺得可能使用該產品的不同用戶類并描述它們相關的特征。 需求規(guī)格說明模板-綜合描述 b.4 運行環(huán)境描述了軟

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論