軟件工程軟件設(shè)計(jì)詳細(xì)設(shè)計(jì)課件_第1頁
軟件工程軟件設(shè)計(jì)詳細(xì)設(shè)計(jì)課件_第2頁
軟件工程軟件設(shè)計(jì)詳細(xì)設(shè)計(jì)課件_第3頁
軟件工程軟件設(shè)計(jì)詳細(xì)設(shè)計(jì)課件_第4頁
軟件工程軟件設(shè)計(jì)詳細(xì)設(shè)計(jì)課件_第5頁
已閱讀5頁,還剩42頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

軟件設(shè)計(jì)

3.1軟件概要設(shè)計(jì)概述3.2軟件設(shè)計(jì)的基本原理3.3軟件結(jié)構(gòu)準(zhǔn)則3.5軟件詳細(xì)設(shè)計(jì)3.6軟件詳細(xì)設(shè)計(jì)表示法3.7小結(jié)3.5軟件詳細(xì)設(shè)計(jì) 3.5.1詳細(xì)設(shè)計(jì)的基本任務(wù) 1.算法設(shè)計(jì) 用某種圖形、表格、語言等工具將每個(gè)模塊處理過程的詳細(xì)算法描述出來。 2.?dāng)?shù)據(jù)結(jié)構(gòu)設(shè)計(jì) 對于需求分析、概要設(shè)計(jì)確定的概念性的數(shù)據(jù)類型進(jìn)行確切的定義。 3.物理設(shè)計(jì) 對數(shù)據(jù)庫進(jìn)行物理設(shè)計(jì),即確定數(shù)據(jù)庫的物理結(jié)構(gòu)。物理結(jié)構(gòu)主要指數(shù)據(jù)庫的存儲(chǔ)記錄格式、存儲(chǔ)記錄安排和存儲(chǔ)方法,這些都依賴于具體所使用的數(shù)據(jù)庫系統(tǒng)。 4.其他設(shè)計(jì) 根據(jù)軟件系統(tǒng)的類型,還可能要進(jìn)行以下設(shè)計(jì): (1)代碼設(shè)計(jì):為了提高數(shù)據(jù)的輸入、分類、存儲(chǔ)及檢索等操作的效率,以及節(jié)約內(nèi)存空間,對數(shù)據(jù)庫中的某些數(shù)據(jù)項(xiàng)的值要進(jìn)行代碼設(shè)計(jì)。 (3)程序1(標(biāo)識符)設(shè)計(jì)說明:包括功能、性能、輸入、輸出、算法、流程邏輯、接口。 (4)程序2(標(biāo)識符)設(shè)計(jì)說明。 (5)程序N(標(biāo)識符)設(shè)計(jì)說明。 6.評審 對處理過程的算法和數(shù)據(jù)庫的物理結(jié)構(gòu)都要評審。

3.5.2詳細(xì)設(shè)計(jì)方法 處理過程設(shè)計(jì)中采用的典型方法是結(jié)構(gòu)化程序設(shè)計(jì)(SP)方法,最早是由E.W.Dijkstra在20世紀(jì)60年代中期提出的。詳細(xì)設(shè)計(jì)并不是具體地編程序,而是已經(jīng)細(xì)化成很容易從中產(chǎn)生程序的圖紙。因此詳細(xì)設(shè)計(jì)的結(jié)果基本決定了最終程序的質(zhì)量。為了提高軟件的質(zhì)量,延長軟件的生存期,軟件的可測試性、可維護(hù)性是重要保障。軟件的可測試性、可維護(hù)性與程序的易讀性有很大關(guān)系。詳細(xì)設(shè)計(jì)的目標(biāo)不僅是邏輯上能正確地實(shí)現(xiàn)每個(gè)模塊的功能,還應(yīng)使設(shè)計(jì)出的處理過程清晰易讀。結(jié)構(gòu)化程序設(shè)計(jì)是實(shí)現(xiàn)該目標(biāo)的關(guān)鍵技術(shù)之一,它指導(dǎo)人們用良好的思想方法開發(fā)易于理解、易于驗(yàn)證的程序。結(jié)構(gòu)化程序設(shè)計(jì)方法有以下幾個(gè)基本要點(diǎn)。 1.采用自頂向下、逐步求精的程序設(shè)計(jì)方法 在需求分析、概要設(shè)計(jì)中,都采用了自頂向下、逐層細(xì)化的方法。使用“抽象”這個(gè)手段,上層對問題抽象、對模塊抽象和對數(shù)據(jù)抽象,下層則進(jìn)一步分解,進(jìn)入另一個(gè)抽象層次。在詳細(xì)設(shè)計(jì)中,雖然處于“具體”設(shè)計(jì)階段,但在設(shè)計(jì)某個(gè)模塊內(nèi)部處理過程中,仍可以逐步求精,降低處理細(xì)節(jié)的復(fù)雜度。三種方式對模糊過程進(jìn)行分解:

(1)用順序方式對過程分解,確定各部分的執(zhí)行順序。 (2)用選擇方式對過程分解,確定某個(gè)部分的執(zhí)行條件。3)用循環(huán)方式對過程分解,確定某個(gè)部分進(jìn)行重復(fù)的開始和結(jié)束的條件。 對處理過程仍然模糊的部分反復(fù)使用以上分解方法,最終可將所有細(xì)節(jié)確定下來。例:在一組數(shù)中找出其中最大的數(shù)

1輸入一組數(shù);1輸入一個(gè)數(shù)組;1輸入一個(gè)數(shù)組;2找出其中的最大數(shù);3輸出最大數(shù)。3輸出最大數(shù)。2.1任取一數(shù),假定它就是最大數(shù);2.2將該數(shù)與其余各數(shù)逐一比較;2.3若發(fā)現(xiàn)任何數(shù)大于假設(shè)的最大數(shù),即取而代之;2.1令”最大數(shù)”=數(shù)組的第一個(gè)元素;2.2從第二個(gè)元素至最后一個(gè)元素做循環(huán);2.3如果新元素>“最大數(shù)”則“最大數(shù)”=新元素;3輸出“最大數(shù)”。求解步驟細(xì)化第二步結(jié)構(gòu)化語言描述問題求解逐步細(xì)化的過程

3.主程序員的組織形式 主程序員的組織形式指開發(fā)程序的人員應(yīng)采用以一個(gè)主程序員(負(fù)責(zé)全部技術(shù)活動(dòng))、一個(gè)后備程序員(協(xié)調(diào)、支持主程序員)和一個(gè)程序管理員(負(fù)責(zé)事務(wù)性工作,如收集、記錄數(shù)據(jù),文檔資料管理等)三人為核心,再加上一些專家(如通信專家、數(shù)據(jù)庫專家)、其他技術(shù)人員組成小組。這種組織形式突出了主程序員的領(lǐng)導(dǎo),設(shè)計(jì)責(zé)任集中在少數(shù)人身上,有利于提高軟件質(zhì)量,并且能有效地提高軟件生產(chǎn)率。這種組織形式最先由IBM公司實(shí)施,隨后其他軟件公司也紛紛采用主程序員制的工作方式。 因此,結(jié)構(gòu)化程序設(shè)計(jì)方法是綜合應(yīng)用這些手段來構(gòu)造高質(zhì)量程序的思想方法。圖3.8三種基本控制結(jié)構(gòu)的流程圖3.6.1程序流程圖 程序流程圖又稱為程序框圖,它是歷史最悠久、使用最廣泛的一種描述程序邏輯結(jié)構(gòu)的工具,圖3.8為流程圖的三種基本控制結(jié)構(gòu)。 流程圖的優(yōu)點(diǎn)是直觀清晰、易于使用,是開發(fā)者普遍采用的工具,但是它有如下嚴(yán)重缺點(diǎn): (1)可以隨心所欲地畫控制流程線的流向,容易造成非結(jié)構(gòu)化的程序結(jié)構(gòu),編碼時(shí)勢必不加限制地使用GOTO語句,導(dǎo)致基本控制塊多入口多出口,這樣會(huì)使軟件質(zhì)量受到影響,與軟件設(shè)計(jì)的原則相違背。 (2)流程圖不能反映逐步求精的過程,往往反映的是最后的結(jié)果。(3)不易表示數(shù)據(jù)結(jié)構(gòu)。 為了克服流程圖的缺陷,要求流程圖都應(yīng)由三種基本控制結(jié)構(gòu)順序組合和完整嵌套而成,不能有相互交叉的情況,這樣的流程圖是結(jié)構(gòu)化的流程圖。

示例

3.6.2PAD圖 PAD圖指問題分析圖(ProblemAnalysisDiagram),是日本日立公司于1979年提出的一種算法描述工具,它是一種由左往右展開的二維樹型結(jié)構(gòu)。PAD圖的基本控制結(jié)構(gòu)如圖3.9所示。圖3.9PAD圖的基本控制結(jié)構(gòu) PAD圖的控制流程為自上而下、從左到右地執(zhí)行。圖3.10給出了將數(shù)組A(1)到A(10)進(jìn)行選擇法排序的算法描述的PAD圖。 從圖3.10給出的例子可以看出PAD圖的優(yōu)點(diǎn)如下: (1)清晰地反映了程序的層次結(jié)構(gòu)。圖中的豎線為程序的層次線,最左邊豎線是程序的主線,其后一層一層展開,層次關(guān)系一目了然。 (2)支持逐步求精的設(shè)計(jì)方法,左邊層次中的內(nèi)容可以抽象,然后由左到右逐步細(xì)化。 (3)易讀易寫,使用方便。

(4)支持結(jié)構(gòu)化的程序設(shè)計(jì)原理。 (5)可自動(dòng)生成程序。PAD圖有對照FORTRAN,Pascal,C等高級語言的標(biāo)準(zhǔn)圖式。因此在有PAD系統(tǒng)的計(jì)算機(jī)上(如日立公司的M系列機(jī)),可以直接輸入PAD圖,由機(jī)器自動(dòng)通過遍歷樹的辦法生成相應(yīng)的源代碼,大大提高了軟件的生產(chǎn)率。PAD圖為軟件的自動(dòng)化生成提供了有力的工具。例.“在一組數(shù)中找出其中最大的數(shù)”的PAD圖MAX=A(1)WHILEii≤nMAX=A(i)對應(yīng)程序段:max:=a[1]i=2WHILEi≤nDOIFa[i]>maxTHENmax:=a[i];i=i+1注.1.A是一個(gè)n元數(shù)組;2.省略變量說明;3.省略輸入、輸出語句。MAX<A(ii)i=i+1練習(xí):計(jì)算n!(要求掌握流程圖、PAD圖)開始結(jié)束輸入nS=1T=1S=S×TT=T+1輸出ST>nTF1.程序流程圖輸入nT=1S=1T=T+1S=S×T輸出S2.PAD圖UNTILT>nGetn;T=1;S=1;Repeat

S=S×T;T=T+1Until

T>n

PrintS;

3.PDL語言 (2)描述處理過程的說明性語言沒有嚴(yán)格的語法。 (3)具有數(shù)據(jù)說明機(jī)制,包括簡單的與復(fù)雜的數(shù)據(jù)說明。 (4)具有模塊定義和調(diào)用機(jī)制,開發(fā)人員應(yīng)根據(jù)系統(tǒng)編程所用的語種,說明PDL表示有關(guān)程序結(jié)構(gòu)。 2.程序結(jié)構(gòu) 用PDL表示的程序結(jié)構(gòu)一般有下列幾種結(jié)構(gòu)。 1)順序結(jié)構(gòu) 采用自然語言描述順序結(jié)構(gòu): 處理S1 處理S2

處理Sn 2)選擇結(jié)構(gòu) (1)IF-EISE結(jié)構(gòu):IF條件IF條件處理S1或處理SELSEENDIF處理S2ENDIF (2)IF-ORIF-ELSE結(jié)構(gòu):IF條件1處理S1ORIF條件2

ELSE處理SnENDIF (3)CASE結(jié)構(gòu): CASEOF CASE(1) 處理S1 CASE(2) 處理S2

ELSE處理Sn ENDCASE 3)重復(fù)結(jié)構(gòu) (1)FOR結(jié)構(gòu):FORi=1TOn循環(huán)體ENDFOR (2)WHILE結(jié)構(gòu):WHILE條件循環(huán)體ENDWHILE (3)UNTIL結(jié)構(gòu):REPEAT循環(huán)體UNTIL條件 4)出口結(jié)構(gòu) (1)ESCAPE結(jié)構(gòu)(退出本層結(jié)構(gòu)): WHILE條件處理S1 ESCAPELIF條件處理S2 ENDWHILE L:… (2)CYCLE結(jié)構(gòu)(循環(huán)內(nèi)部進(jìn)入循環(huán)的下一次): L:WHILE條件處理S1CYCLELIF條件處理S2ENDWHILE 5)擴(kuò)充結(jié)構(gòu) (1)模塊定義: PROCEDURE模塊名(參數(shù))RETURN END (2)模塊調(diào)用: CALL模塊名(參數(shù)) (3)數(shù)據(jù)定義: DECLARE屬性變量名,… 屬性有:字符、整型、實(shí)型、雙精度、指針、數(shù)組及結(jié)構(gòu)等類型。 (4)輸入/輸出: GET(輸入變量表) PUT(輸出變量表)

3.PDL應(yīng)用示例 現(xiàn)以××系統(tǒng)主控模塊詳細(xì)設(shè)計(jì)為例,說明如何用PDL來描述。 PROCEDURE模塊名()清屏;顯示××系統(tǒng)用戶界面;PUT(“請輸入用戶口令:”);GET(password);IFpassword<>系統(tǒng)口令提示警告信息;退出運(yùn)行ENDIF 顯示本系統(tǒng)主菜單;WHILE(true)接收用戶選擇ABC;IFABC=“退出”Break;ENDIF調(diào)用相應(yīng)下層模塊完成用戶選擇功能;ENDWHILE;清屏;RETURNEND 從示例可以看到PDL的總體結(jié)構(gòu)與一般程序完全相同。外語法同相應(yīng)程序語言一致,內(nèi)語法使用自然語言,易編寫,易理解,也很容易轉(zhuǎn)換成源程序。除此以外,還有以下優(yōu)點(diǎn): (1)提供的機(jī)制較圖形全面,為保證詳細(xì)設(shè)計(jì)與編碼的質(zhì)量創(chuàng)造了有利條件。 (2)可將注釋嵌入在源程序中一起作為程序的文檔,并可同高級程序設(shè)計(jì)語言一樣進(jìn)行編輯、修改,有利于軟件的維護(hù)。 (3)可自動(dòng)生成程序代碼,提高軟件生產(chǎn)率。目前已有PDL多種版本(如PDL/pascal,PDL/C,PDL/Ada等),為自動(dòng)生成相應(yīng)代碼提供了便利條件。3.7小結(jié) 從軟件設(shè)計(jì)開始,瀑布模型的各階段都是面向計(jì)算機(jī)領(lǐng)域的。軟件設(shè)計(jì)分為概要設(shè)計(jì)和詳細(xì)設(shè)計(jì)兩個(gè)階段。 概要設(shè)計(jì)的任務(wù)是要建立軟件系統(tǒng)的體系結(jié)構(gòu),即軟件系統(tǒng)要?jiǎng)澐侄嗌賯€(gè)模塊,模塊之間的層次結(jié)構(gòu)和調(diào)用關(guān)系是怎樣的。同時(shí)還要設(shè)計(jì)數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)庫結(jié)構(gòu),設(shè)計(jì)人機(jī)接口等。 概要設(shè)計(jì)還要求遵守相應(yīng)的設(shè)計(jì)原理,如模塊化、抽象、信息隱蔽和模塊獨(dú)立性等原理。在建立軟件體系結(jié)構(gòu)時(shí)還要遵循軟件結(jié)構(gòu)設(shè)計(jì)的一些準(zhǔn)則,如軟件結(jié)構(gòu)的深度、寬度、扇入、扇出要適當(dāng),模塊的作用范圍要在其控制范圍之中等。 軟件體系結(jié)構(gòu)可用軟件結(jié)構(gòu)圖和IPO圖的H圖來描述。概要設(shè)計(jì)的方法可采用結(jié)構(gòu)化方法和面向?qū)ο蠓椒ǖ葋碓O(shè)計(jì)。概要設(shè)計(jì)產(chǎn)生的文檔是概要設(shè)計(jì)說明書。 概要設(shè)計(jì)之后要進(jìn)行軟件詳細(xì)設(shè)計(jì)。軟件詳細(xì)設(shè)計(jì)的主要任務(wù)是描述每個(gè)模塊的算法,即實(shí)現(xiàn)該模塊功能的處理過程,它通常采用結(jié)構(gòu)化程序設(shè)計(jì)來進(jìn)行,采用程序流程圖、PAD圖、PDL語言等工具來描述。 對于某些項(xiàng)目,由于采用了相應(yīng)的開發(fā)工具,如PowerBuilder,Develop2000等,這時(shí)軟件詳細(xì)設(shè)計(jì)階段工作就不太明顯了。

習(xí)題 1.什么是軟件概要設(shè)計(jì)?該階段的基本任務(wù)是什么? 2.軟件設(shè)計(jì)的基本原理包括哪些內(nèi)容? 3.衡

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(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ǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論