版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
軟件工程
第三章軟件設計3.1軟件設計的概念3.2功能獨立性3.3結(jié)構(gòu)化設計方法3.4過程設計1軟件工程3.1軟件設計的概念軟件設計的基本目標是用比較抽象概括的方式確定目標系統(tǒng)如何完成預定的任務,即軟件設計是確定系統(tǒng)的物理模型。從技術(shù)觀點來看,軟件設計包括數(shù)據(jù)設計、體系結(jié)構(gòu)設計、接口設計、過程設計。數(shù)據(jù)設計將實體關(guān)系圖中描述的對象和關(guān)系,以及數(shù)據(jù)字典中描述的詳細數(shù)據(jù)內(nèi)容轉(zhuǎn)化為數(shù)據(jù)結(jié)構(gòu)的定義。2軟件工程體系結(jié)構(gòu)設計定義軟件系統(tǒng)各主要成份之間的關(guān)系。接口設計根據(jù)數(shù)據(jù)流圖定義軟件內(nèi)部各成份之間、軟件與其它協(xié)同系統(tǒng)之間及軟件與用戶之間的交互機制。過程設計則是把結(jié)構(gòu)成份轉(zhuǎn)換成軟件的過程性描述。3軟件工程將分析模型轉(zhuǎn)換為設計數(shù)據(jù)字典數(shù)據(jù)流圖實體關(guān)系圖狀態(tài)轉(zhuǎn)換圖加工規(guī)格說明控制規(guī)格說明數(shù)據(jù)對象描述過程設計接口設計體系結(jié)構(gòu)設計數(shù)據(jù)設計4軟件工程從工程管理角度來看,軟件設計分兩步完成:概要設計和詳細設計。概要設計將軟件需求轉(zhuǎn)化為軟件體系結(jié)構(gòu)確定系統(tǒng)級接口全局數(shù)據(jù)結(jié)構(gòu)或數(shù)據(jù)庫模式。詳細設計確立每個模塊的實現(xiàn)算法和局部數(shù)據(jù)結(jié)構(gòu)用適當方法表示算法和數(shù)據(jù)結(jié)構(gòu)的細節(jié)5軟件工程軟件設計是后續(xù)開發(fā)步驟及軟件維護工作的基礎。如果沒有設計,只能建立一個不穩(wěn)定的系統(tǒng)結(jié)構(gòu)。設計編碼測試維護測試編碼維護有軟件設計沒有軟件設計6軟件工程軟件設計既是過程又是模型。設計過程是一系列的迭代步驟,使設計人員能夠描述目標系統(tǒng)的各個側(cè)面。設計模型首先描述目標系統(tǒng)的整體架構(gòu),然后逐步細化架構(gòu)得到構(gòu)造每個細節(jié)的指導原則,從而得到系統(tǒng)的一系列不同的視圖。良好的設計原則可為設計過程導航。衡量設計過程的技術(shù)原則:設計必須實現(xiàn)分析模型中描述的所有顯式需求,必須滿足用戶希望的所有隱式需求。衡量軟件設計的原則7軟件工程②對于開發(fā)者和未來的維護者而言,設計必須是可讀的、可理解的,使得將來易于編程、易于測試、易于維護。③設計應該給出軟件的全貌,包括從實現(xiàn)角度可看到的數(shù)據(jù)、功能、行為。衡量設計模型的技術(shù)原則設計模型應該是一個分層結(jié)構(gòu)。該結(jié)構(gòu):使用可識別的設計模式搭建系統(tǒng)結(jié)構(gòu)。用顯示良好設計特征的構(gòu)件構(gòu)成??梢杂醚莼姆绞綄崿F(xiàn)。設計應當模塊化。8軟件工程設計應當包含數(shù)據(jù)、體系結(jié)構(gòu)、接口和構(gòu)件(模塊)的清晰的視圖。設計應當根據(jù)將要實現(xiàn)的對象和數(shù)據(jù)模式導出合適的數(shù)據(jù)結(jié)構(gòu)。設計應當建立具有獨立功能特征的構(gòu)件。設計應當建立能夠降低模塊與外部環(huán)境之間復雜連接的接口。設計模型應當通過使用軟件需求信息所驅(qū)動的可重復的方法導出。Davis的軟件設計原則設計應具有可跟蹤性,能回溯到軟件需求;9軟件工程設計不必每次都從頭做起,可以復用已有的設計模式和數(shù)據(jù)模式。設計應當縮小軟件與現(xiàn)實世界中問題的“智力距離”,盡量逼近問題領(lǐng)域的結(jié)構(gòu);設計應具有一致性和集成性。整個系統(tǒng)應具有統(tǒng)一的風格和格式,具有良好的接口。設計結(jié)果應能適應未來可能的變更;設計不是編碼,編碼也不是設計。設計模型的抽象級別比源代碼高。在編碼級別上唯一的設計決策是補充一些實現(xiàn)細節(jié)。10軟件工程設計應具有容錯性和異常處理能力。對于異常數(shù)據(jù)、事件、操作條件等能夠平滑處理。在建立設計方案時就應能評估設計質(zhì)量,而不是在系統(tǒng)編碼之后。應堅持設計評審,減少概念性(語義性)的錯誤。1) 設計應遵循抽象化的原則,包含數(shù)據(jù)抽象和過程抽象。軟件設計的主要手段11軟件工程過程抽象是指在軟件設計中將處理過程的實現(xiàn)細節(jié)隱藏在過程抽象中,可以直接通過模塊接口使用這些處理操作。數(shù)據(jù)抽象是指采用抽象數(shù)據(jù)類型表示數(shù)據(jù),實現(xiàn)數(shù)據(jù)封裝,使得使用者可通過接口使用數(shù)據(jù)而不必關(guān)心數(shù)據(jù)結(jié)構(gòu)的實現(xiàn)。2)設計應遵循自頂向下、逐步細化的原則,建立一個層次的結(jié)構(gòu)。將軟件體系結(jié)構(gòu)自頂向下,對過程細節(jié)和數(shù)據(jù)細節(jié)從抽象到具體,逐層細化,直到用編程語言的語句能夠?qū)崿F(xiàn)為止。12軟件工程3)設計應當遵循模塊化的原則。每個模塊可獨立地開發(fā)、測試,最后組裝成完整的程序。其出發(fā)點是本著將一種復雜問題“分而治之”的原則。其目的是使程序的結(jié)構(gòu)清晰,容易閱讀、理解、測試、修改。Meyer的良好模塊設計方法的標準模塊可分解性可將系統(tǒng)按問題/子問題分解的原則分解成系統(tǒng)的模塊層次結(jié)構(gòu);模塊可組裝性可利用已有的設計構(gòu)件組裝成新系統(tǒng),不必一切從頭開始。13軟件工程模塊可理解性一個模塊可不參考其他模塊而被理解;模塊連續(xù)性對軟件需求的一些微小變更只導致對某個模塊的修改而整個系統(tǒng)不用大動;模塊保護將模塊內(nèi)出現(xiàn)異常情況的影響范圍限制在模塊內(nèi)部;4)設計應遵循信息隱蔽的原則。Patnas主張在開發(fā)時,將每個程序的成分隱藏在模塊內(nèi),定義每一個模塊時盡可能少地顯露其內(nèi)部的處理。14軟件工程每個模塊的實現(xiàn)細節(jié)對于其它模塊是隱蔽的,將來修改軟件時偶然引入錯誤所造成的影響就可以局限在一個或幾個模塊內(nèi)部,不致波及到軟件的其它部分。在可預見將來可能修改的場合,信息隱蔽可以提高軟件的可修改性、可測試性和可移植性。15軟件工程3.2功能獨立性功能獨立性是抽象、模塊化和信息隱蔽的直接產(chǎn)物。如果一個模塊能夠獨立于其他模塊被編程、測試和修改,則該模塊具有功能獨立性。1978年Myers提出用兩個準則來度量功能獨立性,即模塊間的耦合和模塊的內(nèi)聚。內(nèi)聚性:內(nèi)聚是一個模塊內(nèi)部各個元素彼此結(jié)合的緊密程度的度量。耦合性:耦合是模塊間互相連接的緊密程度的度量,它取決于各個模塊之間接口的復雜度、調(diào)用方式以及哪些信息通過接口。16軟件工程非直接
數(shù)據(jù)標記控制外部公共內(nèi)容耦合耦合耦合耦合耦合耦合耦合耦合性功能獨立性模塊間的耦合模塊之間耦合性越強,功能獨立性越差,這樣形成的模塊結(jié)構(gòu)界面不好。17軟件工程非直接耦合(NondirectCoupling)兩個模塊之間沒有直接關(guān)系,它們之間的聯(lián)系完全是通過主模塊的控制和調(diào)用來實現(xiàn)的。非直接耦合的模塊獨立性最強。主模塊ABCEFGXYZ18軟件工程數(shù)據(jù)耦合(DataCoupling)一個模塊訪問另一個模塊時,彼此之間是通過簡單數(shù)據(jù)參數(shù)(不是控制參數(shù)、公共數(shù)據(jù)結(jié)構(gòu)或外部變量)來交換輸入、輸出信息的。p0(x0,y0)p1(x1,y1)數(shù)據(jù)耦合LINE(x0,y0,x1,y1)19軟件工程標記耦合(StampCoupling)一組模塊通過參數(shù)表傳遞記錄信息,就是標記耦合。這個記錄是某一數(shù)據(jù)結(jié)構(gòu)的子結(jié)構(gòu),而不是簡單變量。p0(x0,y0)p1(x1,y1)標記耦合LINE(p0,p1)20軟件工程控制耦合(ControlCoupling)如果一個模塊通過 傳送開關(guān)、標志、 名字等控制參數(shù), 明顯地控制選擇另 一模塊的功能,就 是控制耦合。FlagFlagf1f2fn21軟件工程外部耦合(ExternalCoupling)一組模塊都訪問同一全局簡單變量而不是同一全局數(shù)據(jù)結(jié)構(gòu),而且不是通過參數(shù)表傳遞該全局變量的信息,則稱之為外部耦合。公共耦合(CommonCoupling)若一組模塊都訪問同一個公共數(shù)據(jù)環(huán)境,則它們之間的耦合就稱為公共耦合。公共的數(shù)據(jù)環(huán)境可以是全局數(shù)據(jù)結(jié)構(gòu)、共享的通信區(qū)、內(nèi)存的公共覆蓋區(qū)等。22軟件工程公共耦合的復雜程度隨耦合模塊的個數(shù)增加而顯著增加。若只是兩模塊間有公共數(shù)據(jù)環(huán)境,則公共耦合有兩種情況。松散公共耦合和緊密公共耦合。common公共數(shù)據(jù)區(qū)ABcommon公共數(shù)據(jù)區(qū)AB松散的公共耦合緊密的公共耦合23軟件工程如果發(fā)生下列情形,模塊之間就是內(nèi)容耦合:一個模塊直接訪問另一個模塊的內(nèi)部數(shù)據(jù);一個模塊不通過正常入口轉(zhuǎn)到另一模塊內(nèi)部;兩個模塊有一部分程序代碼重迭(只可能出現(xiàn)在匯編語言中);一個模塊有多個入口。內(nèi)容耦合(ContentCoupling)24軟件工程
c
AB進入另一模塊內(nèi)部模塊代碼重疊ABentry1……entry2……模塊多個入口25軟件工程模塊內(nèi)聚巧合邏輯時間過程通信信息功能內(nèi)聚內(nèi)聚內(nèi)聚內(nèi)聚內(nèi)聚內(nèi)聚內(nèi)聚內(nèi)聚性功能獨立性模塊內(nèi)聚性越強,功能獨立性越好,對于形成的模塊結(jié)構(gòu)有比較好的作用。要求模塊結(jié)構(gòu)達到高內(nèi)聚,低耦合。26軟件工程一個模塊中各個部分都是完成某一具體功能必不可少的組成部分,或者說該模塊中所有部分都是為了完成一項具體功能而協(xié)同工作,緊密聯(lián)系,不可分割的。則稱該模塊為功能內(nèi)聚模塊。功能內(nèi)聚模塊的功能獨立性最強。功能內(nèi)聚(FunctionalCohesion)27軟件工程這種模塊完成多個功能,各個功能相互獨立但都在同一數(shù)據(jù)結(jié)構(gòu)上操作,每一項功能有一個唯一的入口點。這個模塊將根據(jù)不同的要求,確定該執(zhí)行哪一個功能。由于這個模塊的所有功能都是基于同一個數(shù)據(jù)結(jié)構(gòu)(符號表),因此,它是一個信息內(nèi)聚的模塊。信息內(nèi)聚模塊可以看成是多個功能內(nèi)聚模塊的組合,并且達到信息的隱蔽。信息內(nèi)聚(InformationalCohesion)28軟件工程初始化插入刪除查找修改符號表29軟件工程如果一個模塊內(nèi)各功能部分都使用了相同的輸入數(shù)據(jù),或產(chǎn)生了相同的輸出數(shù)據(jù),則稱之為通信內(nèi)聚模塊。通常,通信內(nèi)聚模塊是通過數(shù)據(jù)流圖來定義的。模塊內(nèi)各個功能是緊密相連的。通信內(nèi)聚
(CommunicationCohesion)30軟件工程打印檢驗結(jié)果讀文件文件計算A計算B合并修改文件新文件A結(jié)果B結(jié)果加工記錄31軟件工程使用流程圖做為工具設計程序時,如果流程圖太大,可以把流程圖中的某一部分劃出組成模塊,就得到過程內(nèi)聚模塊。例如,把流程圖中的循環(huán)部分、判定部分、計算部分分成三個模塊,這三個模塊都是過程內(nèi)聚模塊。過程內(nèi)聚(ProceduralCohesion)32軟件工程時間內(nèi)聚又稱為經(jīng)典內(nèi)聚。這種模塊大多為多功能模塊,但模塊的各個功能的執(zhí)行與時間有關(guān),通常要求所有功能必須在同一時間段內(nèi)執(zhí)行。例如,初始化模塊和終止模塊就是時間內(nèi)聚模塊。時間內(nèi)聚(ClassicalCohesion)33軟件工程這種模塊把幾種相關(guān)的功能組合在一起,每次被調(diào)用時,由傳送給模塊的判定參數(shù)來確定該模塊應執(zhí)行哪一種功能。寫一個記錄讀一個記錄判定調(diào)用模塊被調(diào)用模塊邏輯內(nèi)聚(LogicalCohesion)34軟件工程當幾個模塊內(nèi)正好有一段代碼是相同的,將它們抽取出來形成單獨的模塊,即巧合內(nèi)聚模塊。這種模塊沒有獨立功能,各部分之間沒有聯(lián)系,或聯(lián)系很松散。巧合內(nèi)聚(CoincidentalCohesion)ABCMSTOREREC()TONREADMASTERFILEADD1TOx……35軟件工程結(jié)構(gòu)化設計(structureddesign,SD)是一種面向數(shù)據(jù)流的設計方法,它可以與SA方法銜接。結(jié)構(gòu)化設計是基于模塊化、自頂向下細化、結(jié)構(gòu)化程序設計等程序設計技術(shù)基礎上發(fā)展起來的?;舅枷胧菍⑾到y(tǒng)設計成由相對獨立、功能單一的模塊組成的結(jié)構(gòu)。該方法實施的要點是:首先研究、分析和審查數(shù)據(jù)流圖。從軟件3.3結(jié)構(gòu)化設計方法36軟件工程
的需求規(guī)格說明中弄清數(shù)據(jù)流加工的過程,對于發(fā)現(xiàn)的問題及時解決。然后根據(jù)數(shù)據(jù)流圖確定數(shù)據(jù)處理的類型。典型的類型有兩種:變換型和事務型。針對兩種不同類型分別進行分析處理。由數(shù)據(jù)流圖推導出系統(tǒng)的初始結(jié)構(gòu)圖。利用一些啟發(fā)式原則改進系統(tǒng)初始結(jié)構(gòu)圖,直到得到符合要求的結(jié)構(gòu)圖為止。修改和補充數(shù)據(jù)字典。制定測試計劃。37軟件工程在系統(tǒng)結(jié)構(gòu)圖中的模塊傳入模塊
─從下屬模塊取得數(shù)據(jù),經(jīng)過某些處理,再將其傳送給上級模塊。它傳送的數(shù)據(jù)流叫做邏輯輸入數(shù)據(jù)流。傳出模塊
─從上級模塊獲得數(shù)據(jù),進行某些處理,再將其傳送給下屬模塊。它傳送的數(shù)據(jù)流叫做邏輯輸出數(shù)據(jù)流。變換模塊─它從上級模塊取得數(shù)據(jù),進行特定的處理,轉(zhuǎn)換成其它形式,再傳送回上級模塊。38軟件工程協(xié)調(diào)模塊─對所有下屬模塊進行協(xié)調(diào)和管理的模塊。傳入模塊AA傳出模塊DD變換模塊AB協(xié)調(diào)模塊AABB39軟件工程系統(tǒng)結(jié)構(gòu)圖的基本符號模塊調(diào)用數(shù)據(jù)控制信息轉(zhuǎn)接符號系統(tǒng)結(jié)構(gòu)圖的基本符號選擇(判斷)重復40軟件工程模塊調(diào)用示例(a)調(diào)用(b)判斷調(diào)用(c)循環(huán)調(diào)用41軟件工程數(shù)據(jù):模塊之間傳送的數(shù)據(jù)用帶空心圓的箭頭表示,并在旁邊標上數(shù)據(jù)名。控制信息:控制信息與數(shù)據(jù)的主要區(qū)別是前者只反映數(shù)據(jù)的某種狀態(tài)。模塊間的數(shù)據(jù)傳遞AB(a)xyz查職工簡歷讀人事文件(b)職工號簡歷數(shù)據(jù)無此職工42軟件工程數(shù)據(jù)處理的類型
在需求分析階段,面向數(shù)據(jù)流的SA方法產(chǎn)生數(shù)據(jù)流圖DFD。在軟件設計階段,面向數(shù)據(jù)流的SD方法將DFD轉(zhuǎn)換成程序結(jié)構(gòu)圖。數(shù)據(jù)處理即為在DFD中從系統(tǒng)的輸入數(shù)據(jù)流到系統(tǒng)的輸出數(shù)據(jù)流所經(jīng)歷的一連串連續(xù)變換。數(shù)據(jù)處理的類型分為變換流型與事務流型。
43軟件工程變換流
數(shù)據(jù)沿著輸入通路進入系統(tǒng),經(jīng)過一系列數(shù)據(jù)變換,將數(shù)據(jù)的外部形式轉(zhuǎn)換成對應的內(nèi)部表示,然后通過變換中心(也稱主加工)處理,再沿著輸出通路轉(zhuǎn)換成外部形式離開系統(tǒng)。具有這種特性的數(shù)據(jù)流稱為變換流。變換流型DFD可以分成:輸入+變換中心(主加工)+輸出輸入數(shù)據(jù)C變換數(shù)據(jù)CD輸出數(shù)據(jù)D44軟件工程相應于取得數(shù)據(jù)、變換數(shù)據(jù)、給出數(shù)據(jù),變換流型系統(tǒng)結(jié)構(gòu)圖由輸入、變換中心和輸出等三部分組成。45軟件工程事務流
數(shù)據(jù)沿著輸入通路到達一個事務中心,事務中心根據(jù)輸入數(shù)據(jù)(即事務)的類型在若干個動作(稱為活動流)中選擇一個來執(zhí)行,這種數(shù)據(jù)流也稱為事務流。事務流有明顯的事務中心,各活動流以事務中心為起點呈輻射狀流出。在事務流型系統(tǒng)結(jié)構(gòu)圖中,事務中心模塊按所接受的事務的類型,選擇某一事務(活動流)處理模塊執(zhí)行。各事務處理模塊并列。46軟件工程事務中心分派模塊輸出結(jié)果事務1輸入作業(yè)信息事務2事務3事務4作業(yè)信息作業(yè)信息結(jié)果結(jié)果操作1操作2操作3操作4操作5操作6細節(jié)1細節(jié)2細節(jié)3細節(jié)4細節(jié)5細節(jié)647軟件工程變換分析
變換分析從變換流型的數(shù)據(jù)流圖導出系統(tǒng)結(jié)構(gòu)圖.步驟重畫數(shù)據(jù)流圖;區(qū)分有效(邏輯)輸入、有效(邏輯)輸出和變換中心部分;進行一級分解,設計模塊結(jié)構(gòu)的頂層和第一層模塊;進行二級分解,設計輸入、輸出和中心變換部分的中、下層模塊。48軟件工程1.重畫數(shù)據(jù)流圖(平鋪)為了建立系統(tǒng)結(jié)構(gòu),將數(shù)據(jù)流圖平鋪開來,物理輸入畫在左側(cè),物理輸出畫在右側(cè)。如果一個外部實體既是物理輸入又是物理輸出,則兩側(cè)都要畫出它。ABBCEGGHDFCDEABCDEFGH物理輸入物理輸出49軟件工程2.確定邏輯輸入、邏輯輸出
和變換中心部分變換中心是程序的核心功能,它的輸入是邏輯輸入,它的輸出為邏輯輸出。變換中心ABBCEGGHDFCDEABCDEFGH物理輸入物理輸出邏輯輸入邏輯輸出50軟件工程3.第一級分解:
設計模塊結(jié)構(gòu)的頂層和第一層頂層模塊:其功能就是整個系統(tǒng)的功能;輸入控制模塊:接收所有的輸入數(shù)據(jù);變換控制模塊:實現(xiàn)輸入到輸出的變換;輸出控制模塊:產(chǎn)生所有的輸出數(shù)據(jù)。頂層模塊變換控制輸出控制輸入控制51軟件工程變換中心ABBCEGGHDFCDEABCDEFGH物理輸入物理輸出邏輯輸入邏輯輸出主模塊CD、E輸入C輸出D輸出ECCD,EDE邏輯輸入變換中心邏輯輸出52軟件工程4.第二級分解:設計中、下層模塊輸入控制模塊的分解:從變換中心的邊界開始,沿著各輸入通路,把輸入通路上的每個加工映射成輸入控制模塊的一個低層模塊。輸出控制模塊的分解:從變換中心的邊界開始,沿著各輸出通路,把輸出通路上的每個加工映射成輸出控制模塊的一個低層模塊。變換控制模塊的分解:變換控制模塊通常沒有通用的分解方法,應根據(jù)數(shù)據(jù)流圖中變換部分的實際情況進行設計。53軟件工程輸出HGHABBCEGGHDFCD,EABCDEFGH物理輸入物理輸出主模塊CD,E輸入C輸出D輸出ECCD,EDE輸入BBBCBC輸入AABABA輸出GEG輸出FDFDFFEGGGHH54軟件工程輸出HGHABBCEGGHDFCD,EABCDEFGH物理輸入物理輸出主模塊CD,E輸入C輸出D輸出ECCD,EDE輸入BBBCBC輸入AABABA輸出GEG輸出FDFDFFEGGGHH55軟件工程變換分析練習-DFD練習156軟件工程畫出初始結(jié)構(gòu)圖57軟件工程匯款單合格的匯款單處理后的匯款單收據(jù)明細賬變換中心輸出輸入業(yè)務數(shù)據(jù)變換分析練習2-DFD58軟件工程變換分析練習1-轉(zhuǎn)換后的SC59軟件工程事務分析事務分析是從事務流型數(shù)據(jù)流圖導出系統(tǒng)結(jié)構(gòu)圖。步驟:確定事務中心和每條活動流的流特性將事務流型數(shù)據(jù)流圖映射成高層的系統(tǒng)結(jié)構(gòu)進一步分解60軟件工程1.確定事務中心和各活動流的流特性
右圖為事務流型DFD的一般形式。事務中心(圖中的T): 位于活動流的起點, 活動流從該點成輻射狀流出?;顒恿鳎? 可為變換流 可為事務流事務流型的DFD的組成: 輸入流+事務中心+若干條活動流T輸入流事務流活動流61軟件工程右圖為事務流型DFD的高層結(jié)構(gòu)形式。頂層模塊:其功能就是整個系統(tǒng)的功能。接收模塊:接收輸入數(shù)據(jù)。分派模塊:調(diào)度模塊, 控制下層的所有活動模塊。事務模塊:對應活動流, 是該活動流映射成的。2.將事務流型DFD映射成
高層系統(tǒng)結(jié)構(gòu)…頂層模塊分派接收事務1事務2事務n62軟件工程3.進一步分解接收模塊:類同于變換分析中輸入控制模塊的分解?;顒恿髂K:根據(jù)其流特性(變換流或事務流)進一步采用變換分析或事務分析進行分解。
63軟件工程事務分析舉例-DFD64軟件工程事務分析舉例-轉(zhuǎn)換后的SC65軟件工程練習1畫出初始結(jié)構(gòu)圖66軟件工程67軟件工程練習2畫出初始結(jié)構(gòu)圖(變換型與事務型混合)68軟件工程69軟件工程模塊設計的原則在選擇模塊設計的次序時,必須對一個模塊的全部直接下屬模塊都設計完成之后,才能轉(zhuǎn)向另一個模塊的下層模塊的設計。使用“黑盒”技術(shù):在設計當前模塊時,先把該模塊的所有下層模塊定義成“黑盒”,在設計中利用它們時暫不考慮其內(nèi)部結(jié)構(gòu)和實現(xiàn)。在這一步定義好的“黑盒”,在下一步就可以對它們進行設計和加工。最后,全部“黑盒”的內(nèi)容和結(jié)構(gòu)應完全被確定。70軟件工程在設計下層模塊時,應考慮模塊的耦合和內(nèi)聚問題,以提高初始結(jié)構(gòu)圖質(zhì)量。模塊劃分時,一個模塊的直接下屬模塊一般在5個左右。如果直接下屬模塊超過10個,可設立中間層次。如果出現(xiàn)以下情況,就停止模塊分解:模塊不能再細分為明顯的子任務;分解成用戶提供的模塊或庫函數(shù);模塊接口是輸入輸出設備傳送的信息;模塊不宜再分解得過小。71軟件工程變換分析是軟件系統(tǒng)結(jié)構(gòu)設計的主要方法。一般,一個大型的軟件系統(tǒng)是變換型結(jié)構(gòu)和事務型結(jié)構(gòu)的混合結(jié)構(gòu)。所以,我們通常利用以變換分析為主,事務分析為輔的方式進行軟件結(jié)構(gòu)設計。72軟件工程abdpqrsbac1d分派模塊事務控制qrs接受通路p73軟件工程模塊功能完善化一個完整的模塊應當有以下幾部分:執(zhí)行規(guī)定的功能的部分;出錯處理的部分。當模塊不能完成規(guī)定的功能時,必須回送出錯標志,出現(xiàn)例外情況的原因。如果需要返回數(shù)據(jù)給它的調(diào)用者,在完成數(shù)據(jù)加工或結(jié)束時,應當給它的調(diào)用者返回一個狀態(tài)碼。改進系統(tǒng)結(jié)構(gòu)的啟發(fā)式原則74軟件工程消除重復功能,改善軟件結(jié)構(gòu)完全相似:在結(jié)構(gòu)上完全相似,可能只是在數(shù)據(jù)類型上不一致。此時可以采取完全合并的方法。局部相似:找出其相同部分,分離出去,重新定義成一個獨立的下一層模塊。還可以與它的上級模塊合并。75軟件工程R1R2XY相似部分R1R2XYR1+R2XYX+R1Y+R2R1Y+R2X不可取開關(guān)太多76軟件工程模塊的作用范圍應在控制范圍之內(nèi)模塊的控制范圍包括它本身及其所有的從屬模塊。模塊的作用范圍是指模塊內(nèi)一個判定的作用范圍,凡是受這個判定影響的所有模塊都屬于這個判定的作用范圍。如果一個判定的作用范圍包含在這個判定所在模塊的控制范圍之內(nèi),則這種結(jié)構(gòu)是簡單的,否則,它的結(jié)構(gòu)是不簡單的。77軟件工程78軟件工程盡可能減少高扇出結(jié)構(gòu)
如果一個模塊的扇出數(shù)過大,就意味著該模塊過分復雜,需要協(xié)調(diào)和控制過多的下屬模塊。應當適當增加中間層次的控制模塊。PPP1P279軟件工程避免或減少使用病態(tài)聯(lián)接直接病態(tài)聯(lián)接公共數(shù)據(jù)域病態(tài)聯(lián)接通信模塊病態(tài)聯(lián)接ABcommonABTABLEITABABxxxx(a)直接病態(tài)聯(lián)接(b)公共數(shù)據(jù)域病態(tài)聯(lián)接(c)通信模塊病態(tài)聯(lián)接80軟件工程模塊的大小要適中。設計功能可預測的模塊一個功能可預測的模塊,不論內(nèi)部處理細節(jié)如何,但對相同的輸入數(shù)據(jù),總能產(chǎn)生同樣的結(jié)果。但是,如果模塊內(nèi)部蘊藏有一些特殊的鮮為人知的功能時,這個模塊就可能是不可預測的。對于這種模塊,如果調(diào)用者不小心使用,其結(jié)果將不可預測。81軟件工程保存當前標記恢復“以前”標記標記?標記?功能不可預測的模塊82軟件工程在過程設計階段,要決定各個模塊的實現(xiàn)算法,并精確地表達這些算法。對每個模塊規(guī)定的功能以及算法的設計,給出適當?shù)乃惴枋觯簣D形工具:程序流程圖,N-S,PAD,HIPO表格工具:判定表語言工具:PDL,HIPO3.5過程設計(詳細設計)83軟件工程程序流程圖ABABPA1P=1A2=2An=nTSPFFSPT順序型選擇型先判斷重復型后判斷重復型多分支選擇型84軟件工程gabfx1x4x5x6x2x3入口hijcde出口流程圖示例FFFFFTTTTTswitchdo-whiledo-whilewhile-do=1=2=385軟件工程N-S圖ABPFTABPFTAwhile-doPAdo-whilePAP=1=2…=nA1A2…An順序型選擇型(1)選擇型(2)先判斷重復型后判斷重復型多分支選擇型86軟件工程N-S圖(盒圖)示例do-while
x6abx1TTFFx2x4f=1=2=3gido-while
x5hdecwhile-do
x6j87軟件工程N-S圖的嵌套定義形式88軟件工程問題分析圖(PAD)S1SA1A2AnPPP=1=2=nwhile
PSSS1S2S2untilP選擇型順序型多分支選擇型先判斷重復型后判斷重復型89軟件工程PAD示例while-dox3bfgx1ado-whilex6jx4do-whilex5hicdex2=1=2=390軟件工程PDL(ProgramDesignLanguage)PDL是一種用于描述功能模塊的算法設計和加工細節(jié)的語言。稱為設計程序用語言。它是一種偽碼。偽碼的語法規(guī)則分為“外語法”和“內(nèi)語法”。PDL具有嚴格的關(guān)鍵字外語法,用于定義控制結(jié)構(gòu)和數(shù)據(jù)結(jié)構(gòu),同時它的表示實際操作和條件的內(nèi)語法可使用自然語言的詞匯。91軟件工程示例:拼詞檢查程序PROCEDUREspellcheckBEGIN
--*splitdocumentintosinglewords
LOOPgetnextword
addwordtowordlistinsortorder
EXITWHENallwordsprocessed
ENDLOOP
--*lookupwordsindictionary
LOOPgetwordfromwordlist92軟件工程
IFwordnotindictionaryTHEN
--*displaywordsnotindictionary
displaywordpromptonuserterminal
IFuserresponsesayswordOKTHEN
addwordtogoodwordlist
ELSE
addwordtobadwordlist
ENDIF
ENDIF
EXITWHENallwordsprocessed
ENDLOOP93軟件工程
--*createanewwordsdictionary
dictionary:= mergedictionaryandgoodwordlistENDspellcheck為了區(qū)別關(guān)鍵字,規(guī)定關(guān)鍵字一律大寫,其它單詞一律小寫。內(nèi)語法使用自然語言來描述處理特性。內(nèi)語法比較靈活,只要寫清楚就可以,不必考慮語法錯,以利于人們可把主要精力放在描述算法的邏輯上。94軟件工程判定表決策表用于表示程序的靜態(tài)邏輯在決策表中的條件部分給出所有的兩分支判斷的列表,動作部分給出相應的處理要求將程序流程圖中的多分支判斷都改成兩分支判斷95軟件工程gabfx1x6x7x8x2x5入口hijcde出口FFFFFTTTTTswitchdo-whiledo-whilewhile-dox3x4FFFTTT無多分支判斷結(jié)構(gòu)96軟件工程1234567891011121314x1TTTTTFFFFFFFFFx2-----TTTFFFFFFx3--------TTFFFFx4----------TTFFx5-----TFF------x6TTTFF---------x7TFF-----------x8-TFTF-TFTFTFTFaYYYYYYYYYYYYYYbYYYYYYYYYYYYYYc-----Y--------d--------YY----e----------YY--fYYYYY---------g---YY---------h(huán)---YY---------iYYY-----------j--Y-Y--Y-Y-Y-Y97軟件工程HIPO圖HIPO是1976年由IBM公司提出來的,圖既是在開發(fā)過程中的表達工具,又是開發(fā)文檔的編制工具。HIPO圖采用功能框圖和PDL來描述程序邏輯,它由兩部分組成:層次圖(H圖)和IPO圖。層次圖給出程序的層次關(guān)系,IPO圖為程序各部分提供具體的工作細節(jié)。98軟件工程層次圖(H圖)表明各個功能的隸屬關(guān)系。它是自頂向下逐層分解得到的。最高一層是整個系統(tǒng)的名稱和系統(tǒng)的概括功能說明;第二層把系統(tǒng)功能展開,分成幾個框;第二層功能進一步分解,就得到了第三層、第四層,…,直到最后一層。每個框內(nèi)都應有一個名字,用以標識它的功能。還應有一個編號,以記錄它所在的層次及在該層次的位置。層次圖(H圖)99軟件工程盤存/銷售系統(tǒng)1.0.0銷售處理1.1.0盤存處理1.2.0計算銷售記錄
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 《綜合基礎知識》考點特訓《民法》(2020年版)
- 《電子式書寫技巧》課件
- 2024年寫醫(yī)院個人年終工作總結(jié)
- 《學校智能化方案》課件
- 《幼教機構(gòu)行政管理》課件
- 一年級下冊語文部編版課件部首查字法教學課件
- 細胞生命之旅
- 透析樓市調(diào)控奧秘
- 保研面試英文自我介紹范文匯編十篇
- 2023年-2024年新員工入職前安全教育培訓試題附參考答案(預熱題)
- 以諾書-中英對照
- 卵巢黃體破裂的護理
- 供應鏈管理師(三級)認證備考試題及答案
- 廣東高中學業(yè)水平測試考綱考點必背化學
- 2023年新高考北京卷化學高考真題(含解析)
- GB/T 44273-2024水力發(fā)電工程運行管理規(guī)范
- 2024至2030年中國消費級無人機行業(yè)市場預測與投資規(guī)劃分析報告
- 小學生衛(wèi)生知識健康教育精課件
- 《安全評價技術(shù)》課件-蒸氣云爆炸事故后果傷害模型評價
- CJ/T 158-2002 城市污水處理廠管道和設備色標
- NB-T35009-2013抽水蓄能電站選點規(guī)劃編制規(guī)范
評論
0/150
提交評論