架構(gòu)師培訓(xùn)講義軟件架構(gòu)設(shè)計思想與體系創(chuàng)建_第1頁
已閱讀1頁,還剩25頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、第一章第一章軟件架構(gòu)設(shè)計思想與體系創(chuàng)建軟件架構(gòu)設(shè)計思想與體系創(chuàng)建第一節(jié)第一節(jié)軟件架構(gòu)師的角色和應(yīng)掌握的知識體系軟件架構(gòu)師的角色和應(yīng)掌握的知識體系一、軟件架構(gòu)一、軟件架構(gòu)軟件架構(gòu)(softwarearchiecture)的一種定義是這樣的:架構(gòu)是一組有關(guān)如下要素的重要決策:軟件系統(tǒng)的組織,構(gòu)成系統(tǒng)的結(jié)構(gòu)化元素,接口和它們相互協(xié)作的行為的選擇,結(jié)構(gòu)化元素和行為元素組合成粒度更大的子系統(tǒng)的方式的選擇,以及指導(dǎo)這一組織(元素及其接口、協(xié)作和組合

2、方式)的架構(gòu)風(fēng)格的選擇。軟件架構(gòu)可以有多種定義,不管對軟件架構(gòu)如何定義,所有的定義都有一個共同的主題,那就是必須考慮諸如原理、組織、風(fēng)格、模式、職責(zé)、協(xié)作、連接、系統(tǒng)的動機和主要子系統(tǒng)等大尺度方面的問題。軟件架構(gòu)實際上是兩個層面的事情,一個是設(shè)計構(gòu)造一個完整的軟件系統(tǒng),這里的架構(gòu)也稱作軟件體系結(jié)構(gòu)(SoftwareArchiecture)。另一個層面是構(gòu)造一個統(tǒng)一的共享的框架或者稱架構(gòu)(Framewk),這種架構(gòu)事實上是系統(tǒng)的一個基于服

3、務(wù)的層。軟件架構(gòu)在整個軟件開發(fā)過程中,是處在軟件體系結(jié)構(gòu)設(shè)計階段(設(shè)計),它的必要的輸入,是來自需求工程(分析),而它的輸出,是實現(xiàn)設(shè)計(編程),因此這是一個承上啟下過程節(jié)點。在軟件開發(fā)中,架構(gòu)既可以是名詞,也可以是動詞。作為名詞,架構(gòu)包括上面所定義的內(nèi)容。作為動詞,架構(gòu)一部分是調(diào)研,一部分是設(shè)計,更清晰的,是架構(gòu)調(diào)研和架構(gòu)設(shè)計。架構(gòu)調(diào)研:架構(gòu)調(diào)研:是指識別對系統(tǒng)存在或可能存在重大影響的功能性或非功能性需求(特別是非功能性需求),例如市

4、場趨勢、性能、成本、維護和系統(tǒng)演進等。廣義上,是對系統(tǒng)的重大設(shè)計決策有特別影響的需求進行分析。架構(gòu)設(shè)計:架構(gòu)設(shè)計:是對軟件、硬件、網(wǎng)絡(luò)、運營、政策等軟件設(shè)計中的需求和要素進行決策。在統(tǒng)一過程里面,架構(gòu)調(diào)研和架構(gòu)設(shè)計統(tǒng)稱為架構(gòu)分析。軟件架構(gòu)設(shè)計是一個系統(tǒng)工程,它需要系統(tǒng)構(gòu)架師有很寬的知識面,從需求分析、架構(gòu)設(shè)計到類設(shè)計甚至代碼實現(xiàn)都需要有透徹的理解,這之間的關(guān)系是你中有我我中有你,是不可能截然分開的。在這個課程中,我會站在相對抽象的角度,

5、對軟件系統(tǒng)設(shè)計的思想和方法做一些討論,這注意:靈活的把握,實事求是的分析,善意和把握重點的溝通,有先見性的設(shè)計,這是一個優(yōu)秀的系統(tǒng)構(gòu)架師活的靈魂。第二節(jié)第二節(jié)軟件分析和設(shè)計的方法學(xué)問題軟件分析和設(shè)計的方法學(xué)問題由于架構(gòu)設(shè)計的源泉來自于軟件分析,不同的分析與設(shè)計方法,將會帶來完全不同的架構(gòu)思路。從方法學(xué)的角度來講,目前分析和設(shè)計方法主要分為面向過程的方法與面相對象方法兩種。一、面向過程的方法一、面向過程的方法面向過程方法又稱為結(jié)構(gòu)化方法,

6、起源于20世紀(jì)70年代,主要由面向過程分析、面向過程設(shè)計和面向過程編程三部分組成。面向過程分析面向過程分析:幫助開發(fā)人員定義系統(tǒng)需要做什么(處理需求),系統(tǒng)需要存儲和使用那些數(shù)據(jù)(數(shù)據(jù)需求),系統(tǒng)需要什么樣的輸入和輸出,以及如何把這些功能結(jié)合在一起來完成任務(wù)。面向過程分析的主要工具是數(shù)據(jù)流圖(數(shù)據(jù)流圖(DFD)這是一種顯示面向過程分析中產(chǎn)生的輸入、處理、存儲和輸出的圖形模型。在現(xiàn)代面向過程設(shè)計中,也引入了事件的概念。面向過程設(shè)計面向過程

7、設(shè)計:面向過程設(shè)計是為下列事務(wù)提供指導(dǎo):程序集是什么,每個程序應(yīng)該實現(xiàn)哪些功能能,如何把這些程序組成一張層次圖。面向過程設(shè)計的主要工具是結(jié)構(gòu)圖結(jié)構(gòu)圖,這是一種表達(dá)程序模塊層次的圖形模型。面向過程編程面向過程編程:具有一個開始和結(jié)束的程序或者程序塊,并且程序執(zhí)行的每一步都由三部分組成:順序、選擇或者循環(huán)結(jié)構(gòu),實現(xiàn)這種思想的最典型的語言就是C。整個面向過程設(shè)計的根本目標(biāo)是:把復(fù)雜的系統(tǒng)分解成簡單模塊的層次圖。二、面向?qū)ο蟮牡姆椒ǘ?、面向?qū)ο?/p>

8、的的方法面向?qū)ο蟮姆椒ㄓ擅嫦驅(qū)ο蠓治觯∣OA)、面向?qū)ο笤O(shè)計(OOD)以及面向?qū)ο缶幊蹋∣OP)三部分組成。面向?qū)ο蠓椒ㄅc面向過程方法根本區(qū)別,是把信息系統(tǒng)看成一起工作來完成某項任務(wù)的對象集合,而對象是系統(tǒng)對消息作出做出響應(yīng)的事物而對象是系統(tǒng)對消息作出做出響應(yīng)的事物,所以面向?qū)ο蠓椒ㄖ凶钪档藐P(guān)注的不是它該做什么,而是它如何做出反應(yīng),也就是消息,這是和面向過程方法的根本不同。面向?qū)ο蠓治雒嫦驅(qū)ο蠓治觯∣OA):定義在系統(tǒng)中工作的所有類型的

9、對象,并顯示這些對象如何通過相互作用來完成任務(wù),主要工具是統(tǒng)一建模語言(統(tǒng)一建模語言(UML)。面向?qū)ο笤O(shè)計面向?qū)ο笤O(shè)計(OOD):定義在系統(tǒng)中人機進行通訊所必需的所有類型的對象,并對每種類型的對象進行細(xì)化,以便可以用一種具體的語言來實現(xiàn)這些對象。面向?qū)ο缶幊堂嫦驅(qū)ο缶幊蹋∣OP):用某種具體語言(C、Java、C#、C的對象模塊等)來實現(xiàn)各種對象的行為,包括對象間的消息傳遞。這里的關(guān)鍵是類圖:用面向?qū)ο蟮姆椒@示系統(tǒng)中所有對象所屬類的

溫馨提示

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

評論

0/150

提交評論