軟體工程-資料流圖(DFD)畫法《轉載》

來源:互聯網
上載者:User
概念----資料流圖(DFD)

資料流圖(date flow diagram , DFD),是SA方法中用於表示系統邏輯模型的一種工具,它以圖形的方式描繪資料在系統中流動和處理的過程,由於它只反映系統必須完成的邏輯功能,所以它是一種功能模型。

資料流圖是從資料的角度來描述一個系統的,而流程圖則是從對資料加工的角度來描述系統的;資料流圖中的箭頭是資料流,而流程圖中的箭頭則是控制流程,它表達的是程式執行的次序;資料流圖適合於宏觀地分析一個組織業務概況,而程式流程圖只適合於描述系統中某個加工的執行細節。

一、資料流圖的基本組成成分

資料流:是由一組固定成分的資料群組成,表示資料的流向。值得注意的是,資料流圖中描述的是資料流,而不是控制流程。除了流向資料存放區或從資料存放區流出的資料不必命名外,每個資料流必須要有一個合適的名字,以反映該資料流的含義。

加工:加工描述了輸入資料流到輸出資料之間的變換,也就是輸入資料流經過什麼處理後變成了輸出資料。每個加工都有一個名字和編號。編號能反映該加工位於分層的資料流圖的哪個層次和哪張圖中,能夠看出它是由哪個加工分解出來的子加工。

資料存放區:資料存放區表示暫時儲存的資料。每個資料存放區都有一個名字。

外部實體:外部實體是存在於軟體系統之外的人員或組織,他指出資料所需要的發源地或系統所產生的資料的歸屬地。

二、分層資料流圖的設計方法

1、畫子系統的輸入輸出

把整個系統視為一個大的加工,然後根據資料系統從哪些外部實體接收資料流,以及系統發送資料流到那些外部實體,就可以畫出輸入輸出圖。這張圖稱為頂層圖。

2、畫子系統的內部

把頂層圖的加工分解成若干個加工,並用資料流將這些加工串連起來,使得頂層圖的輸入資料經過若干加工處理後,變成頂層圖的輸出資料流。這張圖稱為0層圖。從一個加工畫出一張資料流圖的過程就是對加工的分解。

確定加工的方法:在資料流的組成或值發生變化的地方應該畫出一個加工,這個加工的功能就是實現這一變化,也可以根據系統的功能決定加工。

確定資料流的方法:使用者把若干資料當作一個單位來處理(這些資料一起到達、一起處理)時,可以把這些資料看成一個資料流。

關於資料存放區:對於一些以後某個時間要使用的資料,可以組織成為一個資料存放區來表示。

3、畫加工的內部

把每個加工看作一個小系統,把加工的輸入輸出資料流看成小系統的輸入輸出資料流。於是可以象畫0層圖一樣畫出每個小系統的加工的DFD圖。

4、畫子加工的分解圖

對第三步分解出來的DFD圖中的每個加工,重複第三步的分解過程,直到圖中尚未分解的加工都是足夠簡單的(即不可再分解)。至此,得到了一套分層資料流圖。

5、對資料流圖和加工編號

對於一個軟體系統,其資料流圖可能有許多層,每一層又有許多張圖。為了區分不同的加工和不同的DFD子圖,應該對每張圖進行編號,以便於管理。

● 頂層圖只有一張,圖中的加工也只有一個,所以不必為其編號。

● 0層圖只有一張,圖中的加工號分別是0.1、0.2、…,或者1, 2 。

● 子圖就是父圖中被分解的加工號。

● 子圖中的加工號是由圖號、圓點和序號組成,如:1.12,1.3 等等。

三、應該注意的問題:

1、命名。 應適當的為資料流、加工、資料存放區以及外部實體命名,名字應該反映該成分的實際含義,避免使用空洞的名字。

2、畫資料流圖,不是畫控制流程。資料流反映系統“做什麼”,不反映“如何做”,因此箭頭上的資料流名稱只能是名詞或名詞短語,整個圖中不反映加工的執行順序。

3、一般不畫物質流。資料流反映能用電腦處理的資料,並不是實物,因此對目標系統的資料流圖一般不要畫物質流。

4、一個加工的輸出資料流,不應與輸入資料流同名,即使他們的組成完全相同。

5、允許一個加工有多條資料流流向另一個加工,也允許一個加工有兩條相同的輸出資料流流向不同的加工。

6、編號。如果一張資料流圖中的某個加工分解成另一張資料流圖時,則上層圖為父圖,直接下層圖為子圖。子圖及其所有的加工都應編號。

7、保持父圖與子圖的平衡。也就是說,父圖中的某加工的輸入輸出資料流必須與他的子圖的輸入輸出資料流在數量上和名字上相同。值得注意的是,如果父圖中的一個輸入(輸出)資料流對應於子圖中的幾個輸入(輸出)資料流,而子圖中組成這些資料流的資料項目的全體正好是父圖中的這一個資料流,那麼他們仍然算是平衡的。

8、在自頂向下的分解過程中,若一個資料存放區首次出現時,只與一個加工有關係,那麼這個資料存放區應作為這個加工的內部檔案而不必畫出。

9、保持資料守恒,也就是,一個加工的所有輸出資料流中的資料必須能從該加工的輸出資料流中直接獲得,或者通過該加工能產生的資料。

10、每個加工必須既有輸入資料流,又有輸出資料流。

11、在整套資料流圖中,每個資料存放區必須既有讀的資料流,又有寫的資料流。但是在某張子圖中,可能只有讀沒有寫,或者只有寫沒有讀。

12、提高資料流圖的易懂性。注意合理分解,要把一個加工分解成幾個功能相對獨立的子加工,這樣可以減少加工之間輸入、輸出資料流的數目,增加資料流圖的可理解性。

=============================================================================

基本圖形符號
資料流圖有四種基本圖形符號:
:箭頭,表示資料流;
〇:圓或橢圓,表示加工;
=:雙杠(帶一邊開口,一邊閉合),表示資料存放區;
□:方框,表示資料的源點或終點。
(1) 資料流。資料流是資料在系統內傳播的路徑,因此由一組成分固定的資料群組成。如訂票單由旅客姓名、年齡、單位、社會安全號碼、日期、目的地等資料項目組成。由於資料流是流動中的資料,所以必須有流向,除了與資料存放區之間的資料流不用命名外,資料流應該用名詞或名詞短語命名。
(2)加工(又稱為資料處理)。對資料流進行某些操作或變換。每個加工也要有名字,通常是動詞短語,簡明地描述完成什麼加工。在分層的資料流圖中,加工還應編號。
(3)資料存放區(又稱為檔案),指暫時儲存的資料,它可以是資料庫檔案或任何形式的資料群組織。
(4)資料來源點或終點,是本軟體系統外部環境中的實體(包括人員、組織或其他軟體系統),統稱外部實體。一般只出現在資料流圖的頂層圖。
畫資料流圖的步驟
(1)首先畫系統的輸入輸出,即先畫頂層資料流圖。頂層流圖只包含一個加工,用以表示被開發的系統,然後考慮該系統有哪些輸入資料、輸出資料流。頂層圖的作用在於表明被開發系統的範圍以及它和周圍環境的資料交換關係。為飛機機票預訂系統的頂層圖。
(2)畫系統內部,即畫下層資料流圖。不再分解的加工稱為基本加工。一般將層號從0開始編號,採用自頂向下,由外向內的原則。畫0層資料流圖時,分解頂層流圖的系統為若干子系統,決定每個子系統間的資料介面和活動關係。例如,在上面的機票預訂系統按功能可分成兩部分,一部分為旅行社預訂機票,另一部分為旅客取票,兩部分通過機票檔案的資料存放區聯絡起來,0層資料流圖3-4。
(3)注意事項。
①命名。不論資料流、資料存放區還是加工,合適的命名使人們易於理解其含義。
②畫資料流而不是控制流程。資料流反映系統”做什麼”,不反映“如何做”,因此箭頭上的資料流名稱只能是名詞或名詞短語,整個圖中不反映加工的執行順序。
③一般不畫物質流。資料流反映能用電腦處理的資料,並不是實物,因此對目標系統的資料流圖一般不要畫物質流。
④每個加工至少有一個輸入資料流和一個輸出資料流,反映出此加工資料的來源與加工的結果。
⑤編號。如果一張資料流圖中的某個加工分解成另一張資料流圖時,則上層圖為父圖,直接下層圖為子圖。子圖及其所有的加工都應編號。
⑥父圖與子圖的平衡。子圖的輸入輸出資料流同父圖相應加工的輸入輸出資料流必須一致,此即父圖與子圖的平衡。
⑦局部資料存放區。當某層資料流圖中的資料存放區不是父圖中相應加工的外部介面,而只是本圖中某些加工之間的資料介面,則稱這些資料存放區為局部資料存放區。
⑧提高資料流圖的易懂性。注意合理分解,要把一個加工分解成幾個功能相對獨立的子加工,這樣可以減少加工之間輸入、輸出資料流的數目,增加資料流圖的可理解性。

相關關鍵詞:
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.