《《軟件體系結(jié)構(gòu)》課件》由會員分享,可在線閱讀,更多相關(guān)《《軟件體系結(jié)構(gòu)》課件(33頁珍藏版)》請在裝配圖網(wǎng)上搜索。
1、課 程 內(nèi) 容 軟件體系結(jié)構(gòu)概論 軟件體系結(jié)構(gòu)建模 軟件體系結(jié)構(gòu)風(fēng)格 軟件體系結(jié)構(gòu)描述 動態(tài)軟件體系結(jié)構(gòu) Web服務(wù)體系結(jié)構(gòu) 基于體系結(jié)構(gòu)的軟件開發(fā) 軟件體系結(jié)構(gòu)的分析與測試 軟件體系結(jié)構(gòu)評估 軟件產(chǎn)品線體系結(jié)構(gòu) 軟件體系結(jié)構(gòu)建模的種類 第 2章 軟件體系結(jié)構(gòu)建模 2.1 軟件體系結(jié)構(gòu)建模概述 結(jié)構(gòu)模型 框架模型 動態(tài)模型 過程模型 功能模型 軟件體系結(jié)構(gòu)建模的種類 第 2章 軟件體系結(jié)構(gòu)建模 2.1 軟件體系結(jié)構(gòu)建模概述 結(jié)構(gòu)模型 這是一個最直觀 、 最普遍的建模方法 。 這種方法 以體系結(jié)構(gòu)的構(gòu)件 、 連接件和其他概念來刻畫結(jié)構(gòu) , 并力圖通過結(jié)構(gòu)來反映系統(tǒng)的重要語義內(nèi)容 , 包括系 統(tǒng)的
2、配置 、 約束 、 隱含的假設(shè)條件 、 風(fēng)格 、 性質(zhì)等 。 研究結(jié)構(gòu)模型的核心是體系結(jié)構(gòu)描述語言 。 軟件體系結(jié)構(gòu)建模的種類 第 2章 軟件體系結(jié)構(gòu)建模 2.1 軟件體系結(jié)構(gòu)建模概述 框架模型 框架模型與結(jié)構(gòu)模型類似 , 但它不太側(cè)重描述結(jié)構(gòu) 的細(xì)節(jié)而更側(cè)重于整體的結(jié)構(gòu) 。 框架模型主要以一些特殊的問題為目標(biāo)建立只針對 和適應(yīng)該問題的結(jié)構(gòu) 。 軟件體系結(jié)構(gòu)建模的種類 第 2章 軟件體系結(jié)構(gòu)建模 2.1 軟件體系結(jié)構(gòu)建模概述 動態(tài)模型 動態(tài)模型是對結(jié)構(gòu)或框架模型的補(bǔ)充 , 研究系統(tǒng)的 “ 大顆粒 ” 的行為性質(zhì) 。 例如 , 描述系統(tǒng)的重新配置 或演化 。 動態(tài)可以指系統(tǒng)總體結(jié)構(gòu)的配置 、 建
3、立或拆 除通信通道或計算的過程 。 軟件體系結(jié)構(gòu)建模的種類 第 2章 軟件體系結(jié)構(gòu)建模 2.1 軟件體系結(jié)構(gòu)建模概述 過程模型 過程模型研究構(gòu)造系統(tǒng)的步驟和過程 。 結(jié)構(gòu)是遵循某些過程腳本的結(jié)果 。 軟件體系結(jié)構(gòu)建模的種類 第 2章 軟件體系結(jié)構(gòu)建模 2.1 軟件體系結(jié)構(gòu)建模概述 功能模型 功能模型認(rèn)為體系結(jié)構(gòu)是由一組功能構(gòu)件按層次組 成 , 下層向上層提供服務(wù) 。 功能模型可以看作是一種特殊的框架模型 。 “4+1”模型概述 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 Kruchten在 1995年提出了 “ 4+1”的視圖模型。 “ 4+1”視圖模型從 5個不同的視角包括邏輯視
4、圖 、 進(jìn) 程視圖 、 物理視圖 、 開發(fā)視圖和場景視圖來描述軟件 體系結(jié)構(gòu) 。 每一個視圖只關(guān)心系統(tǒng)的一個側(cè)面 , 5個視圖結(jié)合在 一起才能反映系統(tǒng)的軟件體系結(jié)構(gòu)的全部內(nèi)容 。 “4+1”模型概述 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 邏輯視圖 進(jìn)程視圖 開發(fā)視圖 物理視圖 最終用戶:功能需求 場景 編程人員:軟件管理 系統(tǒng)集成人員:性能 可擴(kuò)充性 、 吞吐量等 系統(tǒng)工程人員:系統(tǒng) 拓?fù)?、 安裝 、 通信等 邏輯視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 邏輯視圖主要支持系統(tǒng)的功能需求 , 即系統(tǒng)提供給 最終用戶的服務(wù) 。 在邏輯視圖中 , 系統(tǒng)分解成一
5、系列 的功能抽象 , 這些抽象主要來自問題領(lǐng)域 。 這種分解 不但可以用來進(jìn)行功能分析 , 而且可用作標(biāo)識在整個 系統(tǒng)的各個不同部分的通用機(jī)制和設(shè)計元素 。 在面向?qū)ο蠹夹g(shù)中 , 通過抽象 、 封裝和繼承 , 可以 用對象模型來代表邏輯視圖 , 用類圖來描述邏輯視圖 。 邏輯視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 可以從 Booch標(biāo)記法中導(dǎo)出邏輯視圖的標(biāo)記法 , 只是從體系結(jié) 構(gòu)級的范疇來考慮這些符號 , 用 Rational Rose進(jìn)行體系結(jié)構(gòu)設(shè) 計 。 構(gòu)件 實例 繼承 使用 包含 , 聚集 關(guān)聯(lián) 類層次 參數(shù)化類 類服務(wù) 類 連接件 邏輯視圖 第 2章 軟件體系
6、結(jié)構(gòu)建模 2.2 “4+1”視圖模型 邏輯視圖中使用的風(fēng)格為面向?qū)ο蟮娘L(fēng)格 , 邏輯視圖設(shè)計中要 注意的主要問題是要保持一個單一的 、 內(nèi)聚的對象模型貫穿整個 系統(tǒng) 。 會話 終端 控制器 轉(zhuǎn)換服務(wù) 連接服務(wù) 編號計劃 邏輯視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 對于規(guī)模更大的系統(tǒng)來說 , 體系結(jié)構(gòu)級中包含數(shù)十甚至數(shù)百個 類 。 顯示及用戶 接口 機(jī)械服務(wù) 基本元素 航空信息 空中交通管 理 飛行管理 外部接口網(wǎng) 關(guān) 仿真和培訓(xùn) 開發(fā)視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 開發(fā)視圖也稱模塊視圖 , 主要側(cè)重于軟件模塊的組 織和管理 。 開發(fā)視圖要考慮
7、軟件內(nèi)部的需求 , 如軟件開發(fā)的容 易性 、 軟件的重用和軟件的通用性 , 要充分考慮由于 具體開發(fā)工具的不同而帶來的局限性 。 開發(fā)視圖通過系統(tǒng)輸入輸出關(guān)系的模型圖和子系統(tǒng)圖 來描述 。 開發(fā)視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 與邏輯視圖一樣 , 可以使用 Booch標(biāo)記法中某些符號來 表示開發(fā)視圖 。 構(gòu)件 參照相關(guān)性模塊 連接件 子系統(tǒng) 層 開發(fā)視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 在開發(fā)視圖中 , 最好采用 4-6層子系統(tǒng) , 而且每個子 系統(tǒng)僅僅能與同層或更低層的子系統(tǒng)通訊 , 這樣可以 使每個層次的接口既完備又精練 , 避免了各個模
8、塊之 間很復(fù)雜的依賴關(guān)系 。 設(shè)計時要充分考慮 , 對于各個層次 , 層次越低 , 通 用性越強(qiáng) , 這樣 , 可以保證應(yīng)用程序的需求發(fā)生改變 時 , 所做的改動最小 。 開發(fā)視圖所用的風(fēng)格通常是層 次結(jié)構(gòu)風(fēng)格 。 開發(fā)視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 公用構(gòu)件 1 低層服務(wù) 支撐機(jī)制:通信、時間、儲存、資源管理等 2 航空類、空中交通管制類 3 空中交通管制功能區(qū):飛行管理、雷達(dá)管理等 4 人機(jī)接口 外部系統(tǒng) 5 離線工具 測試工具 各種各樣的空中 交通管制系統(tǒng) 特定的空中交通 管制系統(tǒng)構(gòu)件 空中交通管制 系統(tǒng)框架 分布式虛擬機(jī) 基本元素 硬件、操作系 統(tǒng)、數(shù)據(jù)庫
9、 領(lǐng) 域 特 定 領(lǐng) 域 無 關(guān) 通 用 空 中 交 通 管 制 代 碼 客 戶 定 制 進(jìn)程視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 進(jìn)程視圖側(cè)重于系統(tǒng)的運(yùn)行特性 , 主要關(guān)注一些非 功能性的需求 。 進(jìn)程視圖強(qiáng)調(diào)并發(fā)性 、 分布性 、 系統(tǒng)集成性和容錯 能力 , 以及從邏輯視圖中的主要抽象如何適合進(jìn)程結(jié) 構(gòu) 。 它也定義邏輯視圖中的各個類的操作具體是在哪 一個線程中被執(zhí)行的 。 進(jìn)程視圖可以描述成多層抽象 , 每個級別分別關(guān)注 不同的方面 。 在最高層抽象中 , 進(jìn)程結(jié)構(gòu)可以看作是 構(gòu)成一個執(zhí)行單元的一組任務(wù) 。 它可看成一系列獨立 的 , 通過邏輯網(wǎng)絡(luò)相互通信的程序
10、。 它們是分布的 , 通過總線或局域網(wǎng) 、 廣域網(wǎng)等硬件資源連接起來 。 進(jìn)程視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 通過擴(kuò)展 Booch對 Ada任務(wù)的表示法 , 來表示進(jìn)程視 圖 。 構(gòu)件 事件廣播 雙向消息 遠(yuǎn)程過程調(diào)用 消息 未指定 連接件 循環(huán)進(jìn)程 簡化進(jìn)程 進(jìn)程 進(jìn)程視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 控制器進(jìn)程 慢周期控 制器任務(wù) 快周期控 制器任務(wù) 主控制 器任務(wù) 終端進(jìn)程 物理視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 物理視圖主要考慮如何把軟件映射到硬件上 , 它通 常要考慮到系統(tǒng)性能 、 規(guī)模 、 可靠性等
11、 。 解決系統(tǒng)拓 撲結(jié)構(gòu) 、 系統(tǒng)安裝 、 通訊等問題 。 當(dāng)軟件運(yùn)行于不同的節(jié)點上時 , 各視圖中的構(gòu)件都 直接或間接地對應(yīng)于系統(tǒng)的不同節(jié)點上 。 因此 , 從軟 件到節(jié)點的映射要有較高的靈活性 , 當(dāng)環(huán)境改變時 , 對系統(tǒng)其他視圖的影響最小 。 物理視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 大型系統(tǒng)的物理視圖可能會變得十分混亂 , 因此可 以與進(jìn)程視圖的映射一道 , 以多種形式出現(xiàn) , 也可單 獨出現(xiàn) 。 構(gòu)件 寬帶或總線 雙向通信 單向通信 臨時通信 通信 其他設(shè)備 處理器 連接件 物理視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 ACS系統(tǒng)的物理視圖
12、 C 主 KKKKKKKK F 備份 F 主 F 備份 F 主 C 備份 物理視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 具有進(jìn)程分配 的小型 ACS系統(tǒng) 的物理視圖 K 會話進(jìn)程 F 終端進(jìn)程 控制器進(jìn)程 物理視圖 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 具有進(jìn)程分 配的大型 ACS系統(tǒng)的 物理視圖 C 中心進(jìn)程 備份節(jié)點 偽中心進(jìn)程 F 會話進(jìn)程 終端進(jìn)程 偽中心進(jìn)程 F 會話進(jìn)程 終端進(jìn)程 K 控制器進(jìn)程 K 控制器進(jìn)程 K 控制器進(jìn)程 更多的K 類 處理器 線路接口卡 線路接口卡線路接口卡 場景 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型
13、場景可以看作是那些重要系統(tǒng)活動的抽象,它使四 個視圖有機(jī)聯(lián)系起來,從某種意義上說場景是最重要的 需求抽象。在開發(fā)體系結(jié)構(gòu)時,它可以幫助設(shè)計者找到 體系結(jié)構(gòu)的構(gòu)件和它們之間的作用關(guān)系。同時,也可以 用場景來分析一個特定的視圖,或描述不同視圖構(gòu)件間 是如何相互作用的。 場景可以用文本表示,也可以用圖形表示。 場景 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 本地呼叫場景的一個原型 (1 )摘機(jī) 小王: 控制器 編號計劃小王: 終端 小王: 會話 (2 )撥號音 (3 )號碼 (4 )號碼 (5 )打 開會話 小結(jié) 第 2章 軟件體系結(jié)構(gòu)建模 2.2 “4+1”視圖模型 邏輯視圖和開發(fā)視
14、圖描述系統(tǒng)的靜態(tài)結(jié)構(gòu),而進(jìn)程 視圖和物理視圖描述系統(tǒng)的動態(tài)結(jié)構(gòu)。 對于不同的軟件系統(tǒng)來說,側(cè)重的角度也有所不同。 例如,對于管理信息系統(tǒng)來說,比較側(cè)重于從邏輯視圖 和開發(fā)視圖來描述系統(tǒng),而對于實時控制系統(tǒng)來說,則 比較注重于從進(jìn)程視圖和物理視圖來描述系統(tǒng)。 第 2章 軟件體系結(jié)構(gòu)建模 2.3 體系結(jié)構(gòu)的核心模型 軟件體系結(jié)構(gòu) 配置 連接件 構(gòu)件 端口 角色 1:N 1:N 1:N 軟件過程 第 2章 軟件體系結(jié)構(gòu)建模 2.4 體系結(jié)構(gòu)的生命周期模型 需求分析 建立體系結(jié)構(gòu) 測試 實現(xiàn) 設(shè)計 生命周期模型 第 2章 軟件體系結(jié)構(gòu)建模 2.4 體系結(jié)構(gòu)的生命周期模型 體系結(jié)構(gòu)的非 形式化描述 體系結(jié)構(gòu)的形式化 基礎(chǔ)(數(shù)學(xué)模型) 體系結(jié)構(gòu)的 規(guī)范描述 體系結(jié)構(gòu)演化 體系結(jié)構(gòu)提供、 評價和度量 體系結(jié)構(gòu)的終結(jié) 體系結(jié)構(gòu)實施 體系結(jié)構(gòu)求精的驗證 體系結(jié)構(gòu)求精 體系結(jié)構(gòu)的 性質(zhì)分析 需要演化 或擴(kuò)展否 否 是 需要求精 否 是 否 第 2章 軟件體系結(jié)構(gòu)建模 2.5 軟件體系結(jié)構(gòu)抽象模型 選讀 第 2章 軟件體系結(jié)構(gòu)建模 本章作業(yè)與思考題 1、選擇一個規(guī)模合適的系統(tǒng),為其建立 “ 4+1”模型。 2、引入了軟件體系結(jié)構(gòu)以后,傳統(tǒng)軟件過程發(fā)生了哪 些變化?這種變化有什么好處? 3、軟件體系結(jié)構(gòu)的生命周期模型與軟件生命周期模型 有什么關(guān)系?