《軟件工程基礎(chǔ)》全套PPT課件
《軟件工程基礎(chǔ)》全套PPT課件,軟件工程基礎(chǔ),軟件工程,基礎(chǔ),全套,PPT,課件
11.1 軟件體系結(jié)構(gòu)的基本概念什么是體系結(jié)構(gòu)什么是體系結(jié)構(gòu)目前還沒有一個公認的關(guān)于軟件體系結(jié)構(gòu)的定義,許多專家目前還沒有一個公認的關(guān)于軟件體系結(jié)構(gòu)的定義,許多專家學者從不同角度對軟件體系結(jié)構(gòu)進行了描述。學者從不同角度對軟件體系結(jié)構(gòu)進行了描述。Bass、Clements和和Kazman給出了如下定義:給出了如下定義:“一個程序或計算機一個程序或計算機系統(tǒng)的軟件體系結(jié)構(gòu)是指系統(tǒng)的軟件體系結(jié)構(gòu)是指系統(tǒng)的一個或者多個結(jié)構(gòu)。結(jié)構(gòu)中系統(tǒng)的一個或者多個結(jié)構(gòu)。結(jié)構(gòu)中包括軟件的構(gòu)件、構(gòu)件的外部可見屬性以及它們之間的相互包括軟件的構(gòu)件、構(gòu)件的外部可見屬性以及它們之間的相互關(guān)系。外部可見屬性則是指軟件構(gòu)件提供的服務(wù)、性能、使關(guān)系。外部可見屬性則是指軟件構(gòu)件提供的服務(wù)、性能、使用特性、錯誤處理、共享資源使用等用特性、錯誤處理、共享資源使用等?!边@一定義強調(diào)在任一體系結(jié)構(gòu)表述中這一定義強調(diào)在任一體系結(jié)構(gòu)表述中“軟件構(gòu)件軟件構(gòu)件”的角色。的角色。DewaynePerry和和A1exanderWo1f曾這樣定義:曾這樣定義:“軟軟件件體系結(jié)構(gòu)是具有一定形式的結(jié)構(gòu)化元素,即構(gòu)件的集合,包體系結(jié)構(gòu)是具有一定形式的結(jié)構(gòu)化元素,即構(gòu)件的集合,包括處理構(gòu)件、數(shù)據(jù)構(gòu)件和連接構(gòu)件。處理構(gòu)件負責對數(shù)據(jù)進括處理構(gòu)件、數(shù)據(jù)構(gòu)件和連接構(gòu)件。處理構(gòu)件負責對數(shù)據(jù)進行加工,數(shù)據(jù)構(gòu)件是被加工的信息,連接構(gòu)件把體系結(jié)構(gòu)的行加工,數(shù)據(jù)構(gòu)件是被加工的信息,連接構(gòu)件把體系結(jié)構(gòu)的不同部分組合連接起來。不同部分組合連接起來?!边@一定義注重區(qū)分處理構(gòu)件、數(shù)據(jù)構(gòu)件和連接構(gòu)件。這一定義注重區(qū)分處理構(gòu)件、數(shù)據(jù)構(gòu)件和連接構(gòu)件。雖然軟件體系結(jié)構(gòu)的定義在變化,但其意圖是清晰的。雖然軟件體系結(jié)構(gòu)的定義在變化,但其意圖是清晰的。體系結(jié)構(gòu)設(shè)計是一系列體系結(jié)構(gòu)設(shè)計是一系列決策和基本原理的集合決策和基本原理的集合,這些決策的,這些決策的目標在于開發(fā)高效的軟件體系結(jié)構(gòu)。在體系結(jié)構(gòu)設(shè)計中所強目標在于開發(fā)高效的軟件體系結(jié)構(gòu)。在體系結(jié)構(gòu)設(shè)計中所強調(diào)的基本原理是系統(tǒng)的可理解性、可維護性和可擴展性。調(diào)的基本原理是系統(tǒng)的可理解性、可維護性和可擴展性。11.1 軟件體系結(jié)構(gòu)的基本概念1模式模式軟件設(shè)計模式是從軟件設(shè)計過程中總結(jié)出來的,是針對軟件設(shè)計模式是從軟件設(shè)計過程中總結(jié)出來的,是針對特定問題的解決方案。建筑師特定問題的解決方案。建筑師C.Alexander對模式給出的對模式給出的經(jīng)典定義是:經(jīng)典定義是:每個模式都描述了一個在我們的環(huán)境中不斷每個模式都描述了一個在我們的環(huán)境中不斷出現(xiàn)的問題及該問題解決方案的核心出現(xiàn)的問題及該問題解決方案的核心。在軟件系統(tǒng)中,可。在軟件系統(tǒng)中,可以將模式劃分為以下以將模式劃分為以下3類。類。(1)體系結(jié)構(gòu)模式體系結(jié)構(gòu)模式(architecturalpattern):表達了軟):表達了軟件系統(tǒng)的基本結(jié)構(gòu)組織形式或者結(jié)構(gòu)方案,包含了一組預件系統(tǒng)的基本結(jié)構(gòu)組織形式或者結(jié)構(gòu)方案,包含了一組預定義的子系統(tǒng),規(guī)定了這些子系統(tǒng)的責任,同時還提供了定義的子系統(tǒng),規(guī)定了這些子系統(tǒng)的責任,同時還提供了用于組織和管理這些子系統(tǒng)的規(guī)則和向?qū)?。典型的體系結(jié)用于組織和管理這些子系統(tǒng)的規(guī)則和向?qū)?。典型的體系結(jié)構(gòu)模式如構(gòu)模式如OSI參考模型參考模型。11.1 軟件體系結(jié)構(gòu)的基本概念體系結(jié)構(gòu)模式、風格和框架的概念體系結(jié)構(gòu)模式、風格和框架的概念(2)設(shè)計模式設(shè)計模式(designpattern):為軟件系統(tǒng)的子系):為軟件系統(tǒng)的子系統(tǒng)、構(gòu)件或者構(gòu)件之間的關(guān)系提供一個精煉之后的解決方統(tǒng)、構(gòu)件或者構(gòu)件之間的關(guān)系提供一個精煉之后的解決方案,描述了在特定環(huán)境下,用于解決通用軟件設(shè)計問題的案,描述了在特定環(huán)境下,用于解決通用軟件設(shè)計問題的構(gòu)件以及這些構(gòu)件相互通信時的各種結(jié)構(gòu)。有代表性的設(shè)構(gòu)件以及這些構(gòu)件相互通信時的各種結(jié)構(gòu)。有代表性的設(shè)計模式是計模式是ErichGamma及其同事提出的及其同事提出的23種設(shè)計模式種設(shè)計模式。(3)慣用法慣用法(idiom):是與編程語言相關(guān)的低級模式,):是與編程語言相關(guān)的低級模式,描述如何實現(xiàn)構(gòu)件的某些功能,或者利用編程語言的特性描述如何實現(xiàn)構(gòu)件的某些功能,或者利用編程語言的特性來實現(xiàn)構(gòu)件內(nèi)部要素之間的通信功能。來實現(xiàn)構(gòu)件內(nèi)部要素之間的通信功能。11.1 軟件體系結(jié)構(gòu)的基本概念2風格風格風格是帶有一種傾向性的模式。同一個問題可以有不同風格是帶有一種傾向性的模式。同一個問題可以有不同的解決問題的方案或模式,但我們根據(jù)經(jīng)驗,通常會強烈的解決問題的方案或模式,但我們根據(jù)經(jīng)驗,通常會強烈傾向于采用特定的模式,這就是風格。傾向于采用特定的模式,這就是風格。每種風格描述每種風格描述一種系統(tǒng)范疇一種系統(tǒng)范疇,該范疇包括:,該范疇包括:(1)一組構(gòu)件一組構(gòu)件(如數(shù)據(jù)庫、計算模塊)完成系統(tǒng)需要的某(如數(shù)據(jù)庫、計算模塊)完成系統(tǒng)需要的某種功能;種功能;(2)一組連接件一組連接件,它們能使構(gòu)件間實現(xiàn),它們能使構(gòu)件間實現(xiàn)“通信通信”、“合作合作”和和“協(xié)調(diào)協(xié)調(diào)”;(3)約束約束,定義構(gòu)件如何集成為一個系統(tǒng);,定義構(gòu)件如何集成為一個系統(tǒng);(4)語義模型語義模型,它能使設(shè)計者通過分析系統(tǒng)的構(gòu)成成分的,它能使設(shè)計者通過分析系統(tǒng)的構(gòu)成成分的性質(zhì)來理解系統(tǒng)的整體性質(zhì)。性質(zhì)來理解系統(tǒng)的整體性質(zhì)。11.1 軟件體系結(jié)構(gòu)的基本概念體系結(jié)構(gòu)風格定義了一個系統(tǒng)家族,即體系結(jié)構(gòu)風格定義了一個系統(tǒng)家族,即一個體系結(jié)構(gòu)定一個體系結(jié)構(gòu)定義一個詞匯表和一組約束義一個詞匯表和一組約束。詞匯表中包含一些構(gòu)件和連接。詞匯表中包含一些構(gòu)件和連接件類型,而這組約束指出系統(tǒng)是如何將這些構(gòu)件和連接件件類型,而這組約束指出系統(tǒng)是如何將這些構(gòu)件和連接件組合起來的。體系結(jié)構(gòu)風格反映了領(lǐng)域中眾多系統(tǒng)所共有組合起來的。體系結(jié)構(gòu)風格反映了領(lǐng)域中眾多系統(tǒng)所共有的結(jié)構(gòu)和語義特性,并指導如何將各個模塊和子系統(tǒng)有效的結(jié)構(gòu)和語義特性,并指導如何將各個模塊和子系統(tǒng)有效地組織成一個完整的系統(tǒng)。地組織成一個完整的系統(tǒng)。對體系結(jié)構(gòu)風格的研究和實踐為大粒度的軟件復用提供對體系結(jié)構(gòu)風格的研究和實踐為大粒度的軟件復用提供了可能。了可能。11.1 軟件測試的基本概念11.1 軟件測試的基本概念3框架框架隨著應(yīng)用的發(fā)展和完善,某些帶有整體性的應(yīng)用模式被隨著應(yīng)用的發(fā)展和完善,某些帶有整體性的應(yīng)用模式被逐漸固定下來,形成特定的框架,包括逐漸固定下來,形成特定的框架,包括基本構(gòu)成元素基本構(gòu)成元素和和關(guān)關(guān)系系??蚣芸蚣苁翘囟☉?yīng)用領(lǐng)域問題的體系結(jié)構(gòu)模式,框架定義是特定應(yīng)用領(lǐng)域問題的體系結(jié)構(gòu)模式,框架定義了基本構(gòu)成單元和關(guān)系后,開發(fā)者就可以集中精力解決業(yè)了基本構(gòu)成單元和關(guān)系后,開發(fā)者就可以集中精力解決業(yè)務(wù)邏輯問題。務(wù)邏輯問題。在組織形式上,框架是一個待實例化的完整系統(tǒng),定義在組織形式上,框架是一個待實例化的完整系統(tǒng),定義了軟件系統(tǒng)的元素和關(guān)系,創(chuàng)建了基本的模塊,定義了涉了軟件系統(tǒng)的元素和關(guān)系,創(chuàng)建了基本的模塊,定義了涉及功能更改和擴充的插件位置。典型的框架例子有及功能更改和擴充的插件位置。典型的框架例子有MFC框框架架和和Struts框架框架。體系結(jié)構(gòu)的重要作用體現(xiàn)在以下三個方面體系結(jié)構(gòu)的重要作用體現(xiàn)在以下三個方面:(1)體系結(jié)構(gòu)的表示有助于風險承擔者(項目干系)體系結(jié)構(gòu)的表示有助于風險承擔者(項目干系人)進行交流。人)進行交流。(2)體系結(jié)構(gòu)突出了早期設(shè)計決策。)體系結(jié)構(gòu)突出了早期設(shè)計決策。(3)軟件體系結(jié)構(gòu)是可傳遞和可復用的模型。)軟件體系結(jié)構(gòu)是可傳遞和可復用的模型。11.1 軟件測試的基本概念體系結(jié)構(gòu)的重要作用體系結(jié)構(gòu)的重要作用當輸入數(shù)據(jù)經(jīng)過一系列的計算和操作構(gòu)件的變換形成輸出當輸入數(shù)據(jù)經(jīng)過一系列的計算和操作構(gòu)件的變換形成輸出數(shù)據(jù)時,可以應(yīng)用這種體系結(jié)構(gòu)。數(shù)據(jù)時,可以應(yīng)用這種體系結(jié)構(gòu)。管道管道/過濾器過濾器、批處理序批處理序列列都屬于數(shù)據(jù)流風格。都屬于數(shù)據(jù)流風格。管道管道/過濾器結(jié)構(gòu)如下圖所示。過濾器結(jié)構(gòu)如下圖所示。11.2 典型的體系結(jié)構(gòu)風格數(shù)據(jù)流風格數(shù)據(jù)流風格管道管道/過濾器結(jié)構(gòu)過濾器結(jié)構(gòu) 從從上上圖圖可可看看出出,管管道道/過過濾濾器器結(jié)結(jié)構(gòu)構(gòu)擁擁有有一一組組被被稱稱為為過過濾濾器器(filter)的的構(gòu)構(gòu)件件,這這些些構(gòu)構(gòu)件件通通過過管管道道(pipe)連連接接,管管道道將將數(shù)數(shù)據(jù)據(jù)從從一一個個構(gòu)構(gòu)件件傳傳送送到到下下一一個個構(gòu)構(gòu)件件。每每個個過過濾濾器器獨獨立立于于其其上上游游和和下下游游的的構(gòu)構(gòu)件件而而工工作作,過過濾濾器器的的設(shè)設(shè)計計要要針針對對某某種種形式的數(shù)據(jù)輸入,并且產(chǎn)生某種特定形式的數(shù)據(jù)輸出。形式的數(shù)據(jù)輸入,并且產(chǎn)生某種特定形式的數(shù)據(jù)輸出。如如果果數(shù)數(shù)據(jù)據(jù)流流退退化化成成為為單單線線的的變變換換,則則稱稱為為批批處處理理序序列列(batchsequential)。這這種種結(jié)結(jié)構(gòu)構(gòu)接接收收一一批批數(shù)數(shù)據(jù)據(jù),然然后后應(yīng)應(yīng)用用一系列連續(xù)的構(gòu)件(過濾器)變換它。一系列連續(xù)的構(gòu)件(過濾器)變換它。11.2 典型的體系結(jié)構(gòu)風格管道管道/過濾器風格具有以下過濾器風格具有以下優(yōu)點優(yōu)點:(1 1)使得軟構(gòu)件具有良好的隱蔽性和高內(nèi)聚、低耦合的特)使得軟構(gòu)件具有良好的隱蔽性和高內(nèi)聚、低耦合的特 點。點。(2 2)允許設(shè)計者將整個系統(tǒng)的輸入)允許設(shè)計者將整個系統(tǒng)的輸入/輸出行為看成是多個過輸出行為看成是多個過 濾器的行為的簡單合成。濾器的行為的簡單合成。(3 3)支持軟件復用。只要提供適合在兩個過濾器之間傳送)支持軟件復用。只要提供適合在兩個過濾器之間傳送 的數(shù)據(jù),任何兩個過濾器都可被連接起來。的數(shù)據(jù),任何兩個過濾器都可被連接起來。(4 4)系統(tǒng)維護和增強系統(tǒng)性能簡單。新的過濾器可以添加)系統(tǒng)維護和增強系統(tǒng)性能簡單。新的過濾器可以添加 到現(xiàn)有系統(tǒng)中來;舊的可以被改進的過濾器替換掉。到現(xiàn)有系統(tǒng)中來;舊的可以被改進的過濾器替換掉。(5 5)允許對一些如吞吐量、死鎖等屬性的分析。)允許對一些如吞吐量、死鎖等屬性的分析。(6 6)支持并行執(zhí)行。每個過濾器是作為一個單獨的任務(wù)完)支持并行執(zhí)行。每個過濾器是作為一個單獨的任務(wù)完 成,因此可與其他任務(wù)并行執(zhí)行。成,因此可與其他任務(wù)并行執(zhí)行。11.2 典型的體系結(jié)構(gòu)風格管道管道/過濾器風格主要過濾器風格主要缺點缺點如下:如下:(1)通常導致進程成為批處理的結(jié)構(gòu)。這是因為雖然過濾)通常導致進程成為批處理的結(jié)構(gòu)。這是因為雖然過濾器可增量式地處理數(shù)據(jù),但它們是獨立的,所以設(shè)計者必須器可增量式地處理數(shù)據(jù),但它們是獨立的,所以設(shè)計者必須將每個過濾器看成一個完整的從輸入到輸出的轉(zhuǎn)換。將每個過濾器看成一個完整的從輸入到輸出的轉(zhuǎn)換。(2)不適合處理交互的應(yīng)用。當需要增量地顯示改變時,)不適合處理交互的應(yīng)用。當需要增量地顯示改變時,這個問題尤為嚴重。這個問題尤為嚴重。(3)因為在數(shù)據(jù)傳輸上沒有通用的標準,每個過濾器都增)因為在數(shù)據(jù)傳輸上沒有通用的標準,每個過濾器都增加了解析和合成數(shù)據(jù)的工作,這樣就導致了系統(tǒng)性能下降,加了解析和合成數(shù)據(jù)的工作,這樣就導致了系統(tǒng)性能下降,并增加了編寫過濾器的復雜性。并增加了編寫過濾器的復雜性。11.2 典型的體系結(jié)構(gòu)風格在此類體系結(jié)構(gòu)中,存在以下在此類體系結(jié)構(gòu)中,存在以下3種子風格。種子風格。1主程序主程序/子程序體系結(jié)構(gòu)子程序體系結(jié)構(gòu)這種傳統(tǒng)的程序結(jié)構(gòu)將功能分解為一個控制層次,其這種傳統(tǒng)的程序結(jié)構(gòu)將功能分解為一個控制層次,其中中“主主”程序調(diào)用一組程序構(gòu)件,這些程序構(gòu)件又去調(diào)用程序調(diào)用一組程序構(gòu)件,這些程序構(gòu)件又去調(diào)用別別的程序構(gòu)件,如下圖所示。這種結(jié)構(gòu)總體上為樹狀結(jié)的程序構(gòu)件,如下圖所示。這種結(jié)構(gòu)總體上為樹狀結(jié)構(gòu),可以在底層存在公共模塊。構(gòu),可以在底層存在公共模塊。11.2 典型的體系結(jié)構(gòu)風格調(diào)用調(diào)用返回風格返回風格主程序主程序/子程序體系結(jié)構(gòu)的子程序體系結(jié)構(gòu)的優(yōu)點優(yōu)點如下如下:(1)可以使用自頂向下,逐步分解的方法得到體系結(jié)構(gòu))可以使用自頂向下,逐步分解的方法得到體系結(jié)構(gòu)圖,典型的拓撲結(jié)構(gòu)為樹狀結(jié)構(gòu)?;诙x圖,典型的拓撲結(jié)構(gòu)為樹狀結(jié)構(gòu)?;诙x使用關(guān)系對子使用關(guān)系對子程序進行分解,使用過程調(diào)用作為程序之間的交互機制。程序進行分解,使用過程調(diào)用作為程序之間的交互機制。(2)采用程序設(shè)計語言支持的單線程控制。)采用程序設(shè)計語言支持的單線程控制。其主要其主要缺點缺點如下如下:(3)子程序的正確性難于判斷。需要運用層次推理來判斷)子程序的正確性難于判斷。需要運用層次推理來判斷子程序的正確性,因為子程序的正確性取決于它調(diào)用的子程子程序的正確性,因為子程序的正確性取決于它調(diào)用的子程序的正確性。序的正確性。(4)子系統(tǒng)的結(jié)構(gòu)不清晰。通??梢詫⒍鄠€子程序合成為)子系統(tǒng)的結(jié)構(gòu)不清晰。通??梢詫⒍鄠€子程序合成為模塊。模塊。11.2 典型的體系結(jié)構(gòu)風格2面向?qū)ο箫L格面向?qū)ο箫L格系統(tǒng)的構(gòu)件封裝了數(shù)據(jù)和必須應(yīng)用到該數(shù)據(jù)上的操系統(tǒng)的構(gòu)件封裝了數(shù)據(jù)和必須應(yīng)用到該數(shù)據(jù)上的操作,構(gòu)件間通過消息傳遞進行通信與合作。與主程序作,構(gòu)件間通過消息傳遞進行通信與合作。與主程序/子程子程序的體系結(jié)構(gòu)相比,面向?qū)ο箫L格中的對象交互會復雜一序的體系結(jié)構(gòu)相比,面向?qū)ο箫L格中的對象交互會復雜一些。面向?qū)ο箫L格與網(wǎng)絡(luò)應(yīng)用的需求在分布性、自治性、些。面向?qū)ο箫L格與網(wǎng)絡(luò)應(yīng)用的需求在分布性、自治性、協(xié)作性、演化性等方面具有內(nèi)在的一致性。協(xié)作性、演化性等方面具有內(nèi)在的一致性。面向?qū)ο箫L格具有以下面向?qū)ο箫L格具有以下優(yōu)點優(yōu)點:(1 1)因為對象對其他對象隱藏它的表示,所以可以改變一)因為對象對其他對象隱藏它的表示,所以可以改變一 個對象的表示,而不影響其他對象。個對象的表示,而不影響其他對象。(2 2)設(shè)計者可將一些數(shù)據(jù)存取操作的問題分解成一些交互)設(shè)計者可將一些數(shù)據(jù)存取操作的問題分解成一些交互 的代理程序的集合。的代理程序的集合。11.2 典型的體系結(jié)構(gòu)風格其其缺點缺點如下如下:(1)為了使一個對象和另一個對象通過過程調(diào)用等進行)為了使一個對象和另一個對象通過過程調(diào)用等進行交互,必須知道對象的標識。只要一個對象的標識交互,必須知道對象的標識。只要一個對象的標識改變了,就必須修改所有其他明確調(diào)用它的對象。改變了,就必須修改所有其他明確調(diào)用它的對象。(2)必須修改所有顯式調(diào)用它的其他對象,并消除由此)必須修改所有顯式調(diào)用它的其他對象,并消除由此帶來的一些副作用。例如,如果帶來的一些副作用。例如,如果A使用了對象使用了對象B,C也使用了對象也使用了對象B,那么,那么,C對對B的使用所造成的對的使用所造成的對A的影響可能是料想不到的。的影響可能是料想不到的。11.2 典型的體系結(jié)構(gòu)風格3層次結(jié)構(gòu)層次結(jié)構(gòu)層次結(jié)構(gòu)的基本結(jié)構(gòu)如下圖所示。在這種體系結(jié)構(gòu)中,整層次結(jié)構(gòu)的基本結(jié)構(gòu)如下圖所示。在這種體系結(jié)構(gòu)中,整個系統(tǒng)被組織成一個分層結(jié)構(gòu),每一層為上層提供服務(wù),并個系統(tǒng)被組織成一個分層結(jié)構(gòu),每一層為上層提供服務(wù),并作為下一層的客戶。作為下一層的客戶。11.2 典型的體系結(jié)構(gòu)風格這種風格支持基于可增加抽象層的設(shè)計。允許將復雜問這種風格支持基于可增加抽象層的設(shè)計。允許將復雜問題分解成一個增量步驟序列的實現(xiàn)。由于每一層最多只影響題分解成一個增量步驟序列的實現(xiàn)。由于每一層最多只影響兩層,同時只要給相鄰層提供相同的接口,允許每層用不同兩層,同時只要給相鄰層提供相同的接口,允許每層用不同的方法實現(xiàn),同樣為軟件復用提供了強大的支持。的方法實現(xiàn),同樣為軟件復用提供了強大的支持。層次結(jié)構(gòu)具有以下層次結(jié)構(gòu)具有以下優(yōu)點優(yōu)點:(1)支持基于抽象程度遞增的系統(tǒng)設(shè)計,使設(shè)計者可以把)支持基于抽象程度遞增的系統(tǒng)設(shè)計,使設(shè)計者可以把一個復雜系統(tǒng)按遞增的步驟進行分解。一個復雜系統(tǒng)按遞增的步驟進行分解。(2)支持功能增強,因為每一層至多和相鄰的上下層交)支持功能增強,因為每一層至多和相鄰的上下層交互,因此,功能的改變最多影響相鄰的內(nèi)外層。互,因此,功能的改變最多影響相鄰的內(nèi)外層。11.2 典型的體系結(jié)構(gòu)風格(3)支持復用。只要提供的服務(wù)接口定義不變,同一層的)支持復用。只要提供的服務(wù)接口定義不變,同一層的不同實現(xiàn)可以交換使用。這樣,就可以定義一組標準不同實現(xiàn)可以交換使用。這樣,就可以定義一組標準的接口,從而允許各種不同的實現(xiàn)方法。的接口,從而允許各種不同的實現(xiàn)方法。其其缺點缺點如下如下:(1)并不是每個系統(tǒng)都可以很容易地劃分為分層的模式,)并不是每個系統(tǒng)都可以很容易地劃分為分層的模式,甚至即使一個系統(tǒng)的邏輯結(jié)構(gòu)是層次化的,出于對系甚至即使一個系統(tǒng)的邏輯結(jié)構(gòu)是層次化的,出于對系統(tǒng)性能的考慮,系統(tǒng)設(shè)計師不得不把一些低級或高級統(tǒng)性能的考慮,系統(tǒng)設(shè)計師不得不把一些低級或高級的功能綜合起來。的功能綜合起來。(2)很難找到一個合適的、正確的層次抽象方法。)很難找到一個合適的、正確的層次抽象方法。11.2 典型的體系結(jié)構(gòu)風格數(shù)據(jù)庫系統(tǒng)數(shù)據(jù)庫系統(tǒng)、超文本系統(tǒng)超文本系統(tǒng)和和黑板系統(tǒng)黑板系統(tǒng)都屬于倉庫風都屬于倉庫風格。在這種風格中,數(shù)據(jù)格。在這種風格中,數(shù)據(jù)倉庫(如文件或數(shù)據(jù)庫)倉庫(如文件或數(shù)據(jù)庫)位于這種體系結(jié)構(gòu)的中心,位于這種體系結(jié)構(gòu)的中心,其他構(gòu)件會經(jīng)常訪問該數(shù)其他構(gòu)件會經(jīng)常訪問該數(shù)據(jù)倉庫,并對倉庫中的數(shù)據(jù)倉庫,并對倉庫中的數(shù)據(jù)進行增加、修改或刪除據(jù)進行增加、修改或刪除操作。右圖為一個典型的操作。右圖為一個典型的倉庫風格的體系結(jié)構(gòu)。倉庫風格的體系結(jié)構(gòu)。11.2 典型的體系結(jié)構(gòu)風格倉庫風格倉庫風格上圖中上圖中,可把中心存儲庫變換成可把中心存儲庫變換成“黑板黑板”,黑板構(gòu)件負責,黑板構(gòu)件負責協(xié)協(xié)調(diào)信息在客戶間的傳遞,當用戶感興趣的數(shù)據(jù)發(fā)生變化時,調(diào)信息在客戶間的傳遞,當用戶感興趣的數(shù)據(jù)發(fā)生變化時,它將通知客戶軟件。黑板系統(tǒng)的組成如下圖所示。黑板系統(tǒng)它將通知客戶軟件。黑板系統(tǒng)的組成如下圖所示。黑板系統(tǒng)的傳統(tǒng)應(yīng)用是信號處理領(lǐng)域,如語音和模式識別。另一應(yīng)用的傳統(tǒng)應(yīng)用是信號處理領(lǐng)域,如語音和模式識別。另一應(yīng)用是松耦合代理數(shù)據(jù)共享存取。是松耦合代理數(shù)據(jù)共享存取。11.2 典型的體系結(jié)構(gòu)風格以上所講的體系結(jié)構(gòu)模型是通用的模型,除了這些通用的以上所講的體系結(jié)構(gòu)模型是通用的模型,除了這些通用的模型以外,對于特定的應(yīng)用還需要特定的體系結(jié)構(gòu)模型。這模型以外,對于特定的應(yīng)用還需要特定的體系結(jié)構(gòu)模型。這些體系結(jié)構(gòu)模型稱為些體系結(jié)構(gòu)模型稱為領(lǐng)域相關(guān)的體系結(jié)構(gòu)領(lǐng)域相關(guān)的體系結(jié)構(gòu)。有兩種領(lǐng)域相關(guān)。有兩種領(lǐng)域相關(guān)的體系結(jié)構(gòu)模型:的體系結(jié)構(gòu)模型:類屬模型類屬模型(genericmodel)和)和參考模型參考模型(referencemodel)。)。11.3 特定領(lǐng)域的軟件體系結(jié)構(gòu) 類屬模型類屬模型類屬模型是從許多實際系統(tǒng)中抽象出來的一般模型,它封類屬模型是從許多實際系統(tǒng)中抽象出來的一般模型,它封裝了這些系統(tǒng)的主要特征。例如,許多圖書館開發(fā)了自己的裝了這些系統(tǒng)的主要特征。例如,許多圖書館開發(fā)了自己的圖書館館藏圖書館館藏/流通系統(tǒng),若把它們的共同功能抽取出來并創(chuàng)建流通系統(tǒng),若把它們的共同功能抽取出來并創(chuàng)建一個讓所有圖書館都認可的系統(tǒng)體系結(jié)構(gòu)模型,這就是類屬一個讓所有圖書館都認可的系統(tǒng)體系結(jié)構(gòu)模型,這就是類屬模型。類屬模型的一個最著名的例子是模型。類屬模型的一個最著名的例子是編譯器模型編譯器模型,由這個,由這個模型已開發(fā)出了數(shù)以千計的編譯器。模型已開發(fā)出了數(shù)以千計的編譯器。參考模型源于對應(yīng)用領(lǐng)域的研究,它參考模型源于對應(yīng)用領(lǐng)域的研究,它描述了一個理想化的包含描述了一個理想化的包含了系統(tǒng)應(yīng)具有的所有特征的軟件體系結(jié)構(gòu)了系統(tǒng)應(yīng)具有的所有特征的軟件體系結(jié)構(gòu)。它是更抽象且是描述。它是更抽象且是描述一大類系統(tǒng)的模型,并且也是對設(shè)計者有關(guān)某類系統(tǒng)的一般結(jié)構(gòu)一大類系統(tǒng)的模型,并且也是對設(shè)計者有關(guān)某類系統(tǒng)的一般結(jié)構(gòu)的指導,如的指導,如Rockwell和和Gera所提出的所提出的軟件工廠參考模型軟件工廠參考模型。以上兩種不同類型的模型之間并不存在嚴格的區(qū)別,也可以將以上兩種不同類型的模型之間并不存在嚴格的區(qū)別,也可以將類屬模型視為參考模型。區(qū)別之一是類屬模型可以直接在設(shè)計中類屬模型視為參考模型。區(qū)別之一是類屬模型可以直接在設(shè)計中復用,而參考模型一般是用于領(lǐng)域概念間的交流和對可能的體系復用,而參考模型一般是用于領(lǐng)域概念間的交流和對可能的體系結(jié)構(gòu)做出比較。另外,類屬模型通常是經(jīng)過結(jié)構(gòu)做出比較。另外,類屬模型通常是經(jīng)過“自下而上自下而上”地對已有地對已有系統(tǒng)的抽象,而參考模型是系統(tǒng)的抽象,而參考模型是“由上到下由上到下”地產(chǎn)生的。它們都是抽象地產(chǎn)生的。它們都是抽象系統(tǒng)表示法。系統(tǒng)表示法。11.3 特定領(lǐng)域的軟件體系結(jié)構(gòu) 參考模型參考模型分布式系統(tǒng)的一個最簡單的模型是多處理器系統(tǒng),系統(tǒng)由分布式系統(tǒng)的一個最簡單的模型是多處理器系統(tǒng),系統(tǒng)由許多進程組成,這些進程可以在不同的處理器上并行運行,許多進程組成,這些進程可以在不同的處理器上并行運行,可以極大地提高系統(tǒng)的性能??梢詷O大地提高系統(tǒng)的性能。由于大型實時系統(tǒng)對響應(yīng)時間要求較高,這種模型在大型由于大型實時系統(tǒng)對響應(yīng)時間要求較高,這種模型在大型實時系統(tǒng)中比較常見。大型實時系統(tǒng)需要實時采集信息,并實時系統(tǒng)中比較常見。大型實時系統(tǒng)需要實時采集信息,并利用采集到的信息進行決策,然后發(fā)送信號給執(zhí)行機構(gòu)。雖利用采集到的信息進行決策,然后發(fā)送信號給執(zhí)行機構(gòu)。雖然,信息采集、決策制定和執(zhí)行控制這些進程可以在同一臺然,信息采集、決策制定和執(zhí)行控制這些進程可以在同一臺處理器上統(tǒng)一調(diào)度執(zhí)行,但使用多處理器能夠提高系統(tǒng)性處理器上統(tǒng)一調(diào)度執(zhí)行,但使用多處理器能夠提高系統(tǒng)性能。能。11.4 分布式系統(tǒng)結(jié)構(gòu) 多處理器體系結(jié)構(gòu)多處理器體系結(jié)構(gòu)客戶機客戶機/服務(wù)器(服務(wù)器(client/server,C/S)體系結(jié)構(gòu)是基于)體系結(jié)構(gòu)是基于資源不對等,且為實現(xiàn)共享而提出來的,由資源不對等,且為實現(xiàn)共享而提出來的,由服務(wù)器服務(wù)器、客戶客戶機機和和網(wǎng)絡(luò)網(wǎng)絡(luò)三部分組成。三部分組成。在在C/S體系結(jié)構(gòu)中,客戶機可以通過遠程調(diào)用來獲取服體系結(jié)構(gòu)中,客戶機可以通過遠程調(diào)用來獲取服務(wù)器提供的服務(wù),因此,客戶機必須知道可用的服務(wù)器的務(wù)器提供的服務(wù),因此,客戶機必須知道可用的服務(wù)器的名字及它們所提供的服務(wù),而服務(wù)器不需要知道客戶機的名字及它們所提供的服務(wù),而服務(wù)器不需要知道客戶機的身份,也不需要知道有多少臺服務(wù)器在運行。身份,也不需要知道有多少臺服務(wù)器在運行。傳統(tǒng)的傳統(tǒng)的C/S體系結(jié)構(gòu)分為兩層。在這種體系結(jié)構(gòu)中,一體系結(jié)構(gòu)分為兩層。在這種體系結(jié)構(gòu)中,一個應(yīng)用系統(tǒng)被劃分為客戶機和服務(wù)器兩部分。典型的兩層個應(yīng)用系統(tǒng)被劃分為客戶機和服務(wù)器兩部分。典型的兩層C/S體系結(jié)構(gòu)如下圖所示。體系結(jié)構(gòu)如下圖所示。11.4 分布式系統(tǒng)結(jié)構(gòu) 客戶客戶/服務(wù)器體系結(jié)構(gòu)服務(wù)器體系結(jié)構(gòu)兩層兩層C/S體系結(jié)構(gòu)可以有兩種形態(tài):體系結(jié)構(gòu)可以有兩種形態(tài):(1)瘦客戶機模型瘦客戶機模型。在瘦客戶機模型中,數(shù)據(jù)管理部分。在瘦客戶機模型中,數(shù)據(jù)管理部分和應(yīng)用邏輯都在服務(wù)器上執(zhí)行,客戶機只負責表示部分。和應(yīng)用邏輯都在服務(wù)器上執(zhí)行,客戶機只負責表示部分。11.4 分布式系統(tǒng)結(jié)構(gòu)(2)胖客戶機模型胖客戶機模型。在這種模型中,服務(wù)器只負責對數(shù)據(jù)。在這種模型中,服務(wù)器只負責對數(shù)據(jù)的管理。客戶機上的軟件實現(xiàn)應(yīng)用邏輯和與系統(tǒng)用戶的交的管理??蛻魴C上的軟件實現(xiàn)應(yīng)用邏輯和與系統(tǒng)用戶的交互?;ァE挚蛻魴C模型能夠利用客戶機的處理能力,比瘦客戶機胖客戶機模型能夠利用客戶機的處理能力,比瘦客戶機模型在分布處理上更有效。但另一方面,隨著企業(yè)規(guī)模的模型在分布處理上更有效。但另一方面,隨著企業(yè)規(guī)模的日益擴大,軟件的復雜程度不斷提高,胖客戶機模型逐漸日益擴大,軟件的復雜程度不斷提高,胖客戶機模型逐漸暴露出了以下缺點:暴露出了以下缺點:開發(fā)成本較高。開發(fā)成本較高。用戶界面風格不一,使用繁雜,不利于推廣使用。用戶界面風格不一,使用繁雜,不利于推廣使用。軟件移植困難。軟件移植困難。軟件維護和升級困難。軟件維護和升級困難。11.4 分布式系統(tǒng)結(jié)構(gòu) 為了解決以上問題,為了解決以上問題,三層三層C/S體系結(jié)構(gòu)體系結(jié)構(gòu)應(yīng)運而生,其結(jié)應(yīng)運而生,其結(jié)構(gòu)圖如下圖所示。與兩層構(gòu)圖如下圖所示。與兩層C/S體系結(jié)構(gòu)相比,體系結(jié)構(gòu)相比,3層層C/S體系結(jié)體系結(jié)構(gòu)中增加了應(yīng)用服務(wù)器??梢詫⒄麄€應(yīng)用邏輯駐留在應(yīng)用構(gòu)中增加了應(yīng)用服務(wù)器。可以將整個應(yīng)用邏輯駐留在應(yīng)用服務(wù)器上,而只有表示層存在于客戶機上。服務(wù)器上,而只有表示層存在于客戶機上。11.4 分布式系統(tǒng)結(jié)構(gòu) 三層三層三層三層C/SC/SC/SC/S體系結(jié)構(gòu)將整個系統(tǒng)分成體系結(jié)構(gòu)將整個系統(tǒng)分成體系結(jié)構(gòu)將整個系統(tǒng)分成體系結(jié)構(gòu)將整個系統(tǒng)分成表示層表示層表示層表示層、應(yīng)用邏輯層應(yīng)用邏輯層應(yīng)用邏輯層應(yīng)用邏輯層和和和和數(shù)據(jù)層數(shù)據(jù)層數(shù)據(jù)層數(shù)據(jù)層三個部分,其數(shù)據(jù)處理流程如下圖所示。三個部分,其數(shù)據(jù)處理流程如下圖所示。三個部分,其數(shù)據(jù)處理流程如下圖所示。三個部分,其數(shù)據(jù)處理流程如下圖所示。11.4 分布式系統(tǒng)結(jié)構(gòu) 11.4 分布式系統(tǒng)結(jié)構(gòu)(1)表示層表示層:表示層是應(yīng)用系統(tǒng)的用戶界面部分,擔負著:表示層是應(yīng)用系統(tǒng)的用戶界面部分,擔負著用戶與應(yīng)用程序之間的對話功能。它用于檢查用戶從鍵盤等用戶與應(yīng)用程序之間的對話功能。它用于檢查用戶從鍵盤等輸入的數(shù)據(jù),顯示應(yīng)用程序輸出的數(shù)據(jù),一般采用圖形用戶輸入的數(shù)據(jù),顯示應(yīng)用程序輸出的數(shù)據(jù),一般采用圖形用戶界面(界面(graphicuserinterface,GUI)。)。(2)應(yīng)用邏輯層應(yīng)用邏輯層:應(yīng)用邏輯層為應(yīng)用系統(tǒng)的主體部分,包:應(yīng)用邏輯層為應(yīng)用系統(tǒng)的主體部分,包含具體的業(yè)務(wù)處理邏輯。通常在功能層中包含有確認用戶對含具體的業(yè)務(wù)處理邏輯。通常在功能層中包含有確認用戶對應(yīng)用和數(shù)據(jù)庫存取權(quán)限的功能以及記錄系統(tǒng)處理日志的功應(yīng)用和數(shù)據(jù)庫存取權(quán)限的功能以及記錄系統(tǒng)處理日志的功能。能。(3)數(shù)據(jù)層數(shù)據(jù)層:數(shù)據(jù)層主要包括數(shù)據(jù)的存儲及對數(shù)據(jù)的存?。簲?shù)據(jù)層主要包括數(shù)據(jù)的存儲及對數(shù)據(jù)的存取操作,一般選擇關(guān)系型數(shù)據(jù)庫管理系統(tǒng)(操作,一般選擇關(guān)系型數(shù)據(jù)庫管理系統(tǒng)(RDBMS)。)。瀏覽器瀏覽器/服務(wù)器服務(wù)器(browser/server,B/S)風格是三層體)風格是三層體系結(jié)構(gòu)的一種實現(xiàn)方式,其具體結(jié)構(gòu)為瀏覽器系結(jié)構(gòu)的一種實現(xiàn)方式,其具體結(jié)構(gòu)為瀏覽器/Web服務(wù)器服務(wù)器/數(shù)據(jù)庫服務(wù)器。數(shù)據(jù)庫服務(wù)器。B/S體系結(jié)構(gòu)如下圖所示。體系結(jié)構(gòu)如下圖所示。11.4 分布式系統(tǒng)結(jié)構(gòu) B/S體系結(jié)構(gòu)主要是利用不斷成熟的體系結(jié)構(gòu)主要是利用不斷成熟的WWW瀏覽器技術(shù),瀏覽器技術(shù),結(jié)合瀏覽器的多種腳本語言,用通用瀏覽器就實現(xiàn)了原來需結(jié)合瀏覽器的多種腳本語言,用通用瀏覽器就實現(xiàn)了原來需要復雜的專用軟件才能實現(xiàn)的強大功能,并節(jié)約了開發(fā)成本。要復雜的專用軟件才能實現(xiàn)的強大功能,并節(jié)約了開發(fā)成本。從某種程度上來說,從某種程度上來說,B/S結(jié)構(gòu)是一種全新的軟件體系結(jié)構(gòu)。結(jié)構(gòu)是一種全新的軟件體系結(jié)構(gòu)。B/S體系結(jié)構(gòu)具有以下優(yōu)點:體系結(jié)構(gòu)具有以下優(yōu)點:(1)基于)基于B/S體系結(jié)構(gòu)的軟件,系統(tǒng)安裝、修改和維護全體系結(jié)構(gòu)的軟件,系統(tǒng)安裝、修改和維護全在服務(wù)器端解決。在服務(wù)器端解決。(2)B/S體系結(jié)構(gòu)還提供了異種機、異種網(wǎng)、異種應(yīng)用服體系結(jié)構(gòu)還提供了異種機、異種網(wǎng)、異種應(yīng)用服務(wù)的聯(lián)機、聯(lián)網(wǎng)和統(tǒng)一服務(wù)的最現(xiàn)實的開放性基礎(chǔ)。務(wù)的聯(lián)機、聯(lián)網(wǎng)和統(tǒng)一服務(wù)的最現(xiàn)實的開放性基礎(chǔ)。11.4 分布式系統(tǒng)結(jié)構(gòu) 與與C/S體系結(jié)構(gòu)相比,體系結(jié)構(gòu)相比,B/S體系結(jié)構(gòu)也有許多不足之處。體系結(jié)構(gòu)也有許多不足之處。(1)B/S體系結(jié)構(gòu)缺乏對動態(tài)頁面的支持能力,沒有集成體系結(jié)構(gòu)缺乏對動態(tài)頁面的支持能力,沒有集成有效的數(shù)據(jù)庫處理功能。有效的數(shù)據(jù)庫處理功能。(2)采用)采用B/S體系結(jié)構(gòu)的應(yīng)用系統(tǒng),在數(shù)據(jù)查詢等響應(yīng)速體系結(jié)構(gòu)的應(yīng)用系統(tǒng),在數(shù)據(jù)查詢等響應(yīng)速度上,要遠遠地低于度上,要遠遠地低于C/S體系結(jié)構(gòu)。體系結(jié)構(gòu)。(3)B/S體系結(jié)構(gòu)的數(shù)據(jù)提交一般以頁面為單位,數(shù)據(jù)的體系結(jié)構(gòu)的數(shù)據(jù)提交一般以頁面為單位,數(shù)據(jù)的動態(tài)交互性不強,不利于在線事務(wù)處理(動態(tài)交互性不強,不利于在線事務(wù)處理(OLTP)應(yīng))應(yīng)用。用。11.4 分布式系統(tǒng)結(jié)構(gòu) 在客戶機在客戶機/服務(wù)器模型中,客戶機和服務(wù)器的地位是不同服務(wù)器模型中,客戶機和服務(wù)器的地位是不同的。為了消除客戶機與服務(wù)器之間的差別,提高系統(tǒng)的伸的。為了消除客戶機與服務(wù)器之間的差別,提高系統(tǒng)的伸縮性以及有效地均衡負載,可采用分布式對象體系結(jié)構(gòu)來縮性以及有效地均衡負載,可采用分布式對象體系結(jié)構(gòu)來設(shè)計系統(tǒng)。設(shè)計系統(tǒng)。分布式對象分布式對象的實質(zhì)是在分布式異構(gòu)環(huán)境下建立應(yīng)用系統(tǒng)的實質(zhì)是在分布式異構(gòu)環(huán)境下建立應(yīng)用系統(tǒng)框架和對象構(gòu)件,它將應(yīng)用服務(wù)分割成具有完整邏輯含義框架和對象構(gòu)件,它將應(yīng)用服務(wù)分割成具有完整邏輯含義的獨立子模塊(我們稱之為的獨立子模塊(我們稱之為構(gòu)件構(gòu)件),各個子模塊可放在同),各個子模塊可放在同一臺服務(wù)器或分布在多臺服務(wù)器上運行,模塊之間通過中一臺服務(wù)器或分布在多臺服務(wù)器上運行,模塊之間通過中間件互相通信。通常將這個中間件稱為軟件總線或?qū)ο笳堥g件互相通信。通常將這個中間件稱為軟件總線或?qū)ο笳?1.4 分布式系統(tǒng)結(jié)構(gòu) 分布式對象體系結(jié)構(gòu)分布式對象體系結(jié)構(gòu)求代理,它的作用是在對象之間提供一個無縫接口。分布式求代理,它的作用是在對象之間提供一個無縫接口。分布式對象體系結(jié)構(gòu)如下圖所示。對象體系結(jié)構(gòu)如下圖所示。11.4 分布式系統(tǒng)結(jié)構(gòu) 分布式對象技術(shù)的應(yīng)用目的分布式對象技術(shù)的應(yīng)用目的是為了降低主服務(wù)器的負荷、是為了降低主服務(wù)器的負荷、共享網(wǎng)絡(luò)資源、平衡網(wǎng)絡(luò)中計算機業(yè)務(wù)處理的分配,提高計共享網(wǎng)絡(luò)資源、平衡網(wǎng)絡(luò)中計算機業(yè)務(wù)處理的分配,提高計算機系統(tǒng)協(xié)同處理的能力,從而使應(yīng)用的實現(xiàn)更為靈活。算機系統(tǒng)協(xié)同處理的能力,從而使應(yīng)用的實現(xiàn)更為靈活。分布式對象技術(shù)的基礎(chǔ)是構(gòu)件。分布式對象技術(shù)的基礎(chǔ)是構(gòu)件。構(gòu)件構(gòu)件是一些獨立的代碼封是一些獨立的代碼封裝體,在分布計算的環(huán)境下可以是裝體,在分布計算的環(huán)境下可以是一個簡單的對象一個簡單的對象,但大多,但大多數(shù)情況下是數(shù)情況下是一組相關(guān)的對象組合體一組相關(guān)的對象組合體,提供一定的服務(wù)。分布,提供一定的服務(wù)。分布式環(huán)境下,構(gòu)件是一些靈活的軟件模塊,它們可以位置透式環(huán)境下,構(gòu)件是一些靈活的軟件模塊,它們可以位置透明、語言獨立和平臺獨立地互相發(fā)送消息,實現(xiàn)請求服務(wù)。明、語言獨立和平臺獨立地互相發(fā)送消息,實現(xiàn)請求服務(wù)。構(gòu)件之間并不存在客戶機與服務(wù)器的界限,接受服務(wù)者扮演構(gòu)件之間并不存在客戶機與服務(wù)器的界限,接受服務(wù)者扮演客戶機的角色,提供服務(wù)者就是服務(wù)器??蛻魴C的角色,提供服務(wù)者就是服務(wù)器。當前主流的分布式對象技術(shù)規(guī)范有當前主流的分布式對象技術(shù)規(guī)范有OMG的的CORBA、Microsoft公司的公司的.NET和和Sun公司的公司的J2EE。它們都支持服務(wù)。它們都支持服務(wù)端構(gòu)件的開發(fā),都有其各自的特點。端構(gòu)件的開發(fā),都有其各自的特點。11.4 分布式系統(tǒng)結(jié)構(gòu) 代理可以用于構(gòu)建帶有隔離組件的分布式軟件系統(tǒng),該代理可以用于構(gòu)建帶有隔離組件的分布式軟件系統(tǒng),該軟件通過遠程服務(wù)調(diào)用進行交互。代理者負責協(xié)調(diào)通信,軟件通過遠程服務(wù)調(diào)用進行交互。代理者負責協(xié)調(diào)通信,諸如轉(zhuǎn)發(fā)請求以及傳遞結(jié)果和異常等。諸如轉(zhuǎn)發(fā)請求以及傳遞結(jié)果和異常等。1991年,年,OMG基于面向?qū)ο蠹夹g(shù),給出了以對象請求代基于面向?qū)ο蠹夹g(shù),給出了以對象請求代理(理(ORB)為中心的分布式應(yīng)用體系結(jié)構(gòu),如下圖所示。)為中心的分布式應(yīng)用體系結(jié)構(gòu),如下圖所示。11.4 分布式系統(tǒng)結(jié)構(gòu) 代理代理在在OMG的對象管理結(jié)構(gòu)中,的對象管理結(jié)構(gòu)中,ORB是一個關(guān)鍵的通信機是一個關(guān)鍵的通信機制,它以實現(xiàn)互操作性為主要目標,處理對象之間的消息制,它以實現(xiàn)互操作性為主要目標,處理對象之間的消息分布。在分布。在ORB之上有之上有4個對象接口:個對象接口:(1)對象服務(wù)對象服務(wù):定義加入:定義加入ORB的系統(tǒng)級服務(wù),如安全的系統(tǒng)級服務(wù),如安全性、命名和事務(wù)處理,它們是與應(yīng)用領(lǐng)域無關(guān)的。性、命名和事務(wù)處理,它們是與應(yīng)用領(lǐng)域無關(guān)的。(2)公共設(shè)施公共設(shè)施:水平級的服務(wù),定義應(yīng)用程序級服務(wù)。:水平級的服務(wù),定義應(yīng)用程序級服務(wù)。(3)領(lǐng)域接口領(lǐng)域接口:面向特定的領(lǐng)域。:面向特定的領(lǐng)域。(4)應(yīng)用接口應(yīng)用接口:面向指定的現(xiàn)實世界應(yīng)用。是指供應(yīng)商或:面向指定的現(xiàn)實世界應(yīng)用。是指供應(yīng)商或用戶借助于用戶借助于ORB、公共對象服務(wù)及公共設(shè)施而開發(fā)的、公共對象服務(wù)及公共設(shè)施而開發(fā)的特定產(chǎn)品。特定產(chǎn)品。11.4 分布式系統(tǒng)結(jié)構(gòu) MVC框架即模型框架即模型視圖視圖控制器(控制器(model-view-controller)框架,它強調(diào)將用戶輸入、數(shù)據(jù)模型和數(shù)據(jù)表)框架,它強調(diào)將用戶輸入、數(shù)據(jù)模型和數(shù)據(jù)表示的方式分開設(shè)計,一個交互式應(yīng)用系統(tǒng)由示的方式分開設(shè)計,一個交互式應(yīng)用系統(tǒng)由模型模型、視圖視圖和和控控制器制器3個部件組成,分別對應(yīng)于內(nèi)部數(shù)據(jù)、數(shù)據(jù)表示和輸入個部件組成,分別對應(yīng)于內(nèi)部數(shù)據(jù)、數(shù)據(jù)表示和輸入/輸出控制部分,其結(jié)構(gòu)如下圖所示。輸出控制部分,其結(jié)構(gòu)如下圖所示。11.5 體系結(jié)構(gòu)框架MVC框架框架11.5 體系結(jié)構(gòu)框架MVC框架框架1.模型對象模型對象模型對象獨立于外在顯示內(nèi)容和形式,代表應(yīng)用領(lǐng)域中的模型對象獨立于外在顯示內(nèi)容和形式,代表應(yīng)用領(lǐng)域中的業(yè)務(wù)實體和業(yè)務(wù)規(guī)則,是業(yè)務(wù)實體和業(yè)務(wù)規(guī)則,是整個模型的核心整個模型的核心。模型對象的變化。模型對象的變化通過事件處理通知視圖和控制器對象。通過事件處理通知視圖和控制器對象。2.視圖對象視圖對象視圖對象代表視圖對象代表GUI對象,并且以用戶需要的格式表示模型對象,并且以用戶需要的格式表示模型狀態(tài),是交互系統(tǒng)與外界的接口。視圖對象可以包含子視狀態(tài),是交互系統(tǒng)與外界的接口。視圖對象可以包含子視圖,子視圖用于顯示模型的不同部分。通常,每個視圖對象圖,子視圖用于顯示模型的不同部分。通常,每個視圖對象對應(yīng)一個控制器對象。對應(yīng)一個控制器對象。11.5 體系結(jié)構(gòu)框架3.控制器對象控制器對象控制器對象代表鼠標和鍵盤事件。它處理用戶的輸入行為控制器對象代表鼠標和鍵盤事件。它處理用戶的輸入行為并給模型發(fā)送業(yè)務(wù)事件,再將業(yè)務(wù)事件解析為模型應(yīng)執(zhí)行并給模型發(fā)送業(yè)務(wù)事件,再將業(yè)務(wù)事件解析為模型應(yīng)執(zhí)行的動作;同時,模型的更新與修改也將通過控制器來通知的動作;同時,模型的更新與修改也將通過控制器來通知視圖,從而保持各個視圖與模型的一致性。視圖,從而保持各個視圖與模型的一致性。MVC的處理過程為的處理過程為:首先控制器接收用戶的請求,并決定:首先控制器接收用戶的請求,并決定應(yīng)該調(diào)用哪個模型來進行處理;然后模型用業(yè)務(wù)邏輯來處應(yīng)該調(diào)用哪個模型來進行處理;然后模型用業(yè)務(wù)邏輯來處理用戶的請求并返回數(shù)據(jù);最后控制器用相應(yīng)的視圖格式理用戶的請求并返回數(shù)據(jù);最后控制器用相應(yīng)的視圖格式化模型返回的數(shù)據(jù),并通過表示層呈現(xiàn)給用戶。其中,?;P头祷氐臄?shù)據(jù),并通過表示層呈現(xiàn)給用戶。其中,模型是核心數(shù)據(jù)和功能,視圖只關(guān)心顯示數(shù)據(jù),控制只關(guān)心型是核心數(shù)據(jù)和功能,視圖只關(guān)心顯示數(shù)據(jù),控制只關(guān)心用戶輸入,這種結(jié)構(gòu)由于將數(shù)據(jù)和業(yè)務(wù)規(guī)則從表示層分開,用戶輸入,這種結(jié)構(gòu)由于將數(shù)據(jù)和業(yè)務(wù)規(guī)則從表示層分開,因此可以最大化地重用代碼。因此可以最大化地重用代碼。11.5 體系結(jié)構(gòu)框架J2EE的核心體系結(jié)構(gòu)就是在的核心體系結(jié)構(gòu)就是在MVC框架的基礎(chǔ)上進行擴展框架的基礎(chǔ)上進行擴展得到的,如下圖所示。得到的,如下圖所示。11.5 體系結(jié)構(gòu)框架J2EE體系結(jié)構(gòu)框架體系結(jié)構(gòu)框架J2EE的核心體系結(jié)構(gòu)框架的核心體系結(jié)構(gòu)框架 客戶層客戶層:用戶通過客戶層與系統(tǒng)交互。該層可以是各種類:用戶通過客戶層與系統(tǒng)交互。該層可以是各種類型的客戶端。例如,可編程客戶端(如基于型的客戶端。例如,可編程客戶端(如基于JavaSwing的客戶端或的客戶端或applet),純),純Web瀏覽器客戶端,瀏覽器客戶端,WML移動移動客戶端等??蛻舳说?。資源層資源層:資源層可以是企業(yè)數(shù)據(jù)庫,電子商務(wù)解決方案中:資源層可以是企業(yè)數(shù)據(jù)庫,電子商務(wù)解決方案中的外部企業(yè)系統(tǒng),或者是外部的外部企業(yè)系統(tǒng),或者是外部SOA服務(wù)。數(shù)據(jù)可以分布在服務(wù)。數(shù)據(jù)可以分布在多個服務(wù)器上。多個服務(wù)器上。從上圖可看出,從上圖可看出,J2EE模型是模型是分層結(jié)構(gòu)分層結(jié)構(gòu),中間的,中間的3層(表示層,層(表示層,業(yè)務(wù)層,集成層)包含應(yīng)用程序構(gòu)件,客戶層和資源層處于業(yè)務(wù)層,集成層)包含應(yīng)用程序構(gòu)件,客戶層和資源層處于應(yīng)用程序的外圍。應(yīng)用程序的外圍。11.5 體系結(jié)構(gòu)框架表示層:表示層:也稱為也稱為Web層或服務(wù)器端表示層,用戶通過表層或服務(wù)器端表示層,用戶通過表示層來訪問應(yīng)用程序。在基于示層來訪問應(yīng)用程序。在基于Web的應(yīng)用系統(tǒng)中,表示的應(yīng)用系統(tǒng)中,表示層由用戶界面代碼和運行于層由用戶界面代碼和運行于Web服務(wù)器或應(yīng)用服務(wù)器上服務(wù)器或應(yīng)用服務(wù)器上的過程組成。參考的過程組成。參考MVC框架,表示層包括視圖構(gòu)件和控框架,表示層包括視圖構(gòu)件和控制器構(gòu)件。制器構(gòu)件。業(yè)務(wù)層:業(yè)務(wù)層:業(yè)務(wù)層包含表示層中的控制器構(gòu)件沒有實現(xiàn)的業(yè)務(wù)層包含表示層中的控制器構(gòu)件沒有實現(xiàn)的一部分應(yīng)用邏輯。它負責確認和執(zhí)行企業(yè)范圍內(nèi)的業(yè)務(wù)一部分應(yīng)用邏輯。它負責確認和執(zhí)行企業(yè)范圍內(nèi)的業(yè)務(wù)規(guī)則和事務(wù),并管理從資源層加載到應(yīng)用程序高速緩存規(guī)則和事務(wù),并管理從資源層加載到應(yīng)用程序高速緩存中的業(yè)務(wù)對象。中的業(yè)務(wù)對象。集成層:集成層:集成層負責建立和維護與數(shù)據(jù)源的連接。例如,集成層負責建立和維護與數(shù)據(jù)源的連接。例如,通過通過JDBC與數(shù)據(jù)庫進行通信,利用與數(shù)據(jù)庫進行通信,利用Java消息服務(wù)消息服務(wù)(JMS)與外部系統(tǒng)聯(lián)合。)與外部系統(tǒng)聯(lián)合。11.5 體系結(jié)構(gòu)框架1PCMEF框架框架表示表示控制控制中介者中介者實體實體基礎(chǔ)(基礎(chǔ)(presentation-control-mediator-entity-foundation,PCMEF)是一個垂)是一個垂直層次的分層體系結(jié)構(gòu)框架。每一層是可以包含其他包的包。直層次的分層體系結(jié)構(gòu)框架。每一層是可以包含其他包的包。PCMEF框架包含框架包含4層:表示層、控制層、領(lǐng)域?qū)雍突A(chǔ)層。層:表示層、控制層、領(lǐng)域?qū)雍突A(chǔ)層。領(lǐng)域?qū)影瑑蓚€預定義包:實體(領(lǐng)域?qū)影瑑蓚€預定義包:實體(entity)包和中介者)包和中介者(mediator)包。)包。PCMEF框架中包的依賴性主要是向下依賴性。表示層依框架中包的依賴性主要是向下依賴性。表示層依賴于控制層,控制層依賴于領(lǐng)域?qū)?,中介者包依賴于實體包賴于控制層,控制層依賴于領(lǐng)域?qū)樱薪檎甙蕾囉趯嶓w包和基礎(chǔ)層和基礎(chǔ)層,如下圖所示如下圖所示。PCMEF與與PCBMER框架框架11.5 體系結(jié)構(gòu)框架表示層表示層:包含定義包含定義GUI對象的類。對象的類??刂茖涌刂茖?處理表示層的請求,負責處理表示層的請求,負責大多數(shù)程序邏輯、算法、主要計大多數(shù)程序邏輯、算法、主要計算以及為每個用戶維持會話狀態(tài)。算以及為每個用戶維持會話狀態(tài)。領(lǐng)域?qū)宇I(lǐng)域?qū)?其實體包處理控制請求其實體包處理控制請求,中介者包用于創(chuàng)建一個協(xié)調(diào)實體中介者包用于創(chuàng)建一個協(xié)調(diào)實體類和基礎(chǔ)類的通信通道。類和基礎(chǔ)類的通信通道。基礎(chǔ)層基礎(chǔ)層:負責與數(shù)據(jù)庫和負責與數(shù)據(jù)庫和Web服務(wù)服務(wù)的所有通信。的所有通信。11.5 體系結(jié)構(gòu)框架PCMEF框架框架 2.PCBMER框架框架PCBMER框架由框架由PCMEF框架框架擴展而成擴展而成,代表著表示代表著表示控制控制器器Bean中介者中介者實體實體資源(資源(presentation-control-bean-mediator-entity-resource,PCBMER)。其)。其核心體系結(jié)構(gòu)框架如右圖所示。核心體系結(jié)構(gòu)框架如右圖所示。11.5 體系結(jié)構(gòu)框架PCBMER的核心框架的核心框架 在上圖中,把層表示為在上圖中,把層表示為UML包(子系統(tǒng),層),帶箭頭的包(子系統(tǒng),層),帶箭頭的虛線表示依賴關(guān)系。例如,表示層依賴控制器層和虛線表示依賴關(guān)系。例如,表示層依賴控制器層和bean層,控層,控制器層依賴制器層依賴bean層。層。PCBMER的層次不是嚴格線性的,上層可的層次不是嚴格線性的,上層可以依賴多個相鄰下層。以依賴多個相鄰下層。bean層層:表示那些預先確定要呈現(xiàn)在用戶界面上的數(shù)據(jù)類和:表示那些預先確定要呈現(xiàn)在用戶界面上的數(shù)據(jù)類和值對象。除了用戶輸入外,值對象。除了用戶輸入外,bean數(shù)據(jù)由實體對象(實體層)數(shù)據(jù)由實體對象(實體層)創(chuàng)建。創(chuàng)建。表示層:表示層:表示屏幕以及呈現(xiàn)表示屏幕以及呈現(xiàn)bean對象的對象的UI對象。對象??刂破鲗涌刂破鲗樱罕硎緫?yīng)用邏輯。:表示應(yīng)用邏輯。實體層:實體層:響應(yīng)控制器和中介者。響應(yīng)控制器和中介者。中介者層:中介者層:建立了充當實體類和資源類媒介的通信管道。建立了充當實體類和資源類媒介的通信管道。資源層資源層:負責所有與外部持久數(shù)據(jù)資源(數(shù)據(jù)庫、:負責所有與外部持久數(shù)據(jù)資源(數(shù)據(jù)庫、Web服務(wù)服務(wù)等)的通信。等)的通信。11.5 體系結(jié)構(gòu)框架在在UML中,體系結(jié)構(gòu)建模是以結(jié)點、構(gòu)件、包、子系統(tǒng)中,體系結(jié)構(gòu)建模是以結(jié)點、構(gòu)件、包、子系統(tǒng)等概念為中心的。另外,等概念為中心的。另外,UML還可以通過給類圖增加設(shè)計約還可以通過給類圖增加設(shè)計約束支持體系結(jié)構(gòu)建模。所采用的主要形式是在類及其他模型束支持體系結(jié)構(gòu)建模。所采用的主要形式是在類及其他模型中增加依賴關(guān)系。中增加依賴關(guān)系。依賴依賴是體系結(jié)構(gòu)框架的基礎(chǔ),它還決定體是體系結(jié)構(gòu)框架的基礎(chǔ),它還決定體系結(jié)構(gòu)的復雜性。系結(jié)構(gòu)的復雜性。體系結(jié)構(gòu)設(shè)計描述了建立計算機系統(tǒng)所需的數(shù)據(jù)結(jié)構(gòu)和程體系結(jié)構(gòu)設(shè)計描述了建立計算機系統(tǒng)所需的數(shù)據(jù)結(jié)構(gòu)和程序構(gòu)件。一個好的體系結(jié)構(gòu)設(shè)計要求軟件模塊的分層及編程序構(gòu)件。一個好的體系結(jié)構(gòu)設(shè)計要求軟件模塊的分層及編程標準的執(zhí)行。在面向?qū)ο筌浖?,常見的軟件模塊有標準的執(zhí)行。在面向?qū)ο筌浖?,常見的軟件模塊有類類、接接口口、包包和和構(gòu)件構(gòu)件。在。在設(shè)計階段設(shè)計階段我們往往我們往往關(guān)注類、接口和包關(guān)注類、接口和包,而,而在在實現(xiàn)階段實現(xiàn)階段則則關(guān)注構(gòu)件關(guān)注構(gòu)件,而在,而在部署階段部署階段則則關(guān)注構(gòu)件的部署關(guān)注構(gòu)件的部署,也就是將構(gòu)件部署在哪些結(jié)點上。也就是將構(gòu)件部署在哪些結(jié)點上。11.6 體系結(jié)構(gòu)建模1.類類 在面向?qū)ο蟮某绦蛟O(shè)計中,在面向?qū)ο蟮某绦蛟O(shè)計中,類和接口是程序的基本組成類和接口是程序的基本組成單元單元。一個典型程序需要界面類專門負責表示用戶界面信。一個典型程序需要界面類專門負責表示用戶界面信息,需要數(shù)據(jù)庫類負責與數(shù)據(jù)庫進行交互,需要有業(yè)務(wù)邏息,需要數(shù)據(jù)庫類負責與數(shù)據(jù)庫進行交互,需要有業(yè)務(wù)邏輯類負責算法計算等。在計算機程序中,要設(shè)計和實現(xiàn)的輯類負責算法計算等。在計算機程序中,要設(shè)計和實現(xiàn)的所有類都具有唯一的名字,在不同的階段或從不同的角度所有類都具有唯一的名字,在不同的階段或從不同的角度可以將它們稱為可以將它們稱為設(shè)計類設(shè)計類、實現(xiàn)類實現(xiàn)類、系統(tǒng)類系統(tǒng)類、應(yīng)用類應(yīng)用類等。等。11.6 體系結(jié)構(gòu)建模類及其依賴性類及其依賴性2繼承依賴性繼承依賴性依賴性管理中最棘手的問題是由于繼承所引起的依賴依賴性管理中最棘手的問題是由于繼承所引起的依賴性。性。繼承是一種在父類和子類之間共享屬性和行為的方式繼承是一種在父類和子類之間共享屬性和行為的方式,所以運行時可以用一個子類對象代替其父類對象。程序中凡所以運行時可以用一個子類對象代替其父類對象。程序中凡是使用父類對象的地方,都可以用子類對象來代替。一個子是使用父類對象的地方,都可以用子類對象來代替。一個子類對象是一種特殊的父類對象,它繼承父類的所有特征,同類對象是一種特殊的父類對象,它繼承父類的所有特征,同時它又可以覆蓋父類的方法,從而改變從父類繼承的一些特時它又可以覆蓋父類的方法,從而改變從父類繼承的一些特征,并可以在子類中增加一些新的功能。這樣,從客戶的角征,并可以在子類中增加一些新的功能。這樣,從客戶的角度看,在繼承樹中為請求提供服務(wù)的特定對象不同,系統(tǒng)的度看,在繼承樹中為請求提供服務(wù)的特定對象不同,系統(tǒng)的運行行為可能會有所不同。運行行為可能會有所不同。11.6 體系結(jié)構(gòu)建模(1)多態(tài)繼承)多態(tài)繼承根據(jù)為請求提供服務(wù)的對象不同可以得到不同的行為,這根據(jù)為請求提供服務(wù)的對象不同可以得到不同的行為,這種現(xiàn)象稱為種現(xiàn)象稱為多態(tài)多態(tài)。在運行時對類進行實例化,并調(diào)用與實例。在運行時對類進行實例化,并調(diào)用與實例化對象相應(yīng)的方法,稱為化對象相應(yīng)的方法,稱為動態(tài)綁定動態(tài)綁定、后期綁定或運行時綁、后期綁定或運行時綁定。相應(yīng)地,如果方法的調(diào)用是在編譯時確定的,則稱為是定。相應(yīng)地,如果方法的調(diào)用是在編譯時確定的,則稱為是靜態(tài)綁定靜態(tài)綁定、前期綁定或編譯時綁定。、前期綁定或編譯時綁定。多態(tài)并不是伴隨著繼承而出現(xiàn)。如果在子類中不覆蓋父類多態(tài)并不是伴隨著繼承而出現(xiàn)。如果在子類中不覆蓋父類中的任何方法,就不會產(chǎn)生多態(tài)行為。中的任何方法,就不會產(chǎn)生多態(tài)行為。很明顯,繼承會帶來類和方法之間的依賴性。繼承帶來的很明顯,繼承會帶來類和方法之間的依賴性。繼承帶來的依賴性有依賴性有編譯時繼承依賴性編譯時繼承依賴性和和運行時繼承依賴性運行時繼承依賴性。11.6 體系結(jié)構(gòu)建模11.6 體系結(jié)構(gòu)建模編譯時繼承依賴性編譯時繼承依賴性右圖所示的例子說明了一棵樹中類之間的編右圖所示的例子說明了一棵樹中類之間的編譯時依賴性。在這個例子中,譯時依賴性。在這個例子中,B繼承繼承A,但沒有,但沒有覆蓋覆蓋A中的方法中的方法do1()。因此,。因此,B和和A之間沒有之間沒有運行時繼承依賴性。也就是說,由于編譯時依運行時繼承依賴性。也就是說,由于編譯時依賴性的存在,賴性的存在,A中中do1()方法的任何變化,都會方法的任何變化,都會被被B在編譯時(靜態(tài)地)繼承。在編譯時(靜態(tài)地)繼承。一般來說,一般來說,所有的繼承都會引入編譯時依賴所有的繼承都會引入編譯時依賴性性。依賴性是。依賴性是可傳遞的可傳遞的,也就是說,如果,也就是說,如果C依賴依賴B,B依賴依賴A,那么,那么C也依賴也依賴A。運行時繼承依賴性運行時繼承依賴性下圖舉例說明了在一棵繼承樹中涉及客戶對象訪問類服務(wù)的運行時下圖舉例說明了在一棵繼承樹中涉及客戶對象訪問類服務(wù)的運行時繼承依賴性。圖中類繼承依賴性。圖中類B的的do1()方法是從父類方法是從父類A繼承來的,因此繼承來的,因此Test與與B沒有運行時繼承依賴性,只是一個靜態(tài)依賴性,通過從沒有運行時繼承依賴性,只是一個靜態(tài)依賴性,通過從Test到到A的關(guān)的關(guān)聯(lián)來表明。如果在聯(lián)來表明。如果在doTest方法中調(diào)用的是方法中調(diào)用的是do2()方法,或者在方法,或者在B中覆蓋中覆蓋了了A的的do1()方法,則從方法,則從Test到到A和和B就會存在運行時依賴性。就會存在運行時依賴性。11.6 體系結(jié)構(gòu)建模(2)無多態(tài)繼承)無多態(tài)繼承使用繼承最簡單的方式是子類不覆蓋從父類繼承來的方法,使用繼承最簡單的方式是子類不覆蓋從父類繼承來的方法,這樣就不存在多態(tài)性繼承問題。雖然無多態(tài)的繼承有時并不這樣就不存在多態(tài)性繼承問題。雖然無多態(tài)的繼承有時并不是十分有用,但理解和管理起來是最容易的。是十分有用,但理解和管理起來是最容易的。(3)擴展繼承和約束繼承)擴展繼承和約束繼承擴展繼承擴展繼承是指子類繼承父類的屬性,并且提供額外屬性來是指子類繼承父類的屬性,并且提供額外屬性來增強類定義。子類是父類的一種,如果子類覆蓋了父類的方增強類定義。子類是父類的一種,如果子類覆蓋了父類的方法,那么被覆蓋的方法應(yīng)該實現(xiàn)該方法的定義,并且能夠在法,那么被覆蓋的方法應(yīng)該實現(xiàn)該方法的定義,并且能夠在子類的語境中工作。子類的語境中工作。當一個類覆蓋了繼承來的方法,并對一些繼承來的功能進當一個類覆蓋了繼承來的方法,并對一些繼承來的功能進行了限制,這時就產(chǎn)生了行了限制,這時就產(chǎn)生了約束繼承約束繼承。這時,子類不再是父類。這時,子類不再是父類的一種。有時,限制會造成繼承方法的完全禁止。當方法的的一種。有時,限制會造成繼承方法的完全禁止。當方法的實現(xiàn)是空時,就會發(fā)生這種情況。實現(xiàn)是空時,就會發(fā)生這種情況。11.6 體系結(jié)構(gòu)建模3交互依賴性交互依賴性交互依賴性也稱為方法依賴性,是通過消息連接產(chǎn)生的。交互依賴性也稱為方法依賴性,是通過消息連接產(chǎn)生的。如下圖所示。如下圖所示。11.6 體系結(jié)構(gòu)建模圖中,圖中,CActioner使用方法使用方法do1()來發(fā)送一條消息來發(fā)送一條消息do3()給給EEmployee,因此,因此,do1()依賴于依賴于do3()。依賴性向上傳。依賴性向上傳遞給所屬的類,因此,遞給所屬的類,因此,CActione
收藏
編號:65494723
類型:共享資源
大?。?span id="yck6ckg" class="font-tahoma">6.60MB
格式:ZIP
上傳時間:2022-03-24
40
積分
- 關(guān) 鍵 詞:
-
軟件工程基礎(chǔ)
軟件工程
基礎(chǔ)
全套
PPT
課件
- 資源描述:
-
《軟件工程基礎(chǔ)》全套PPT課件,軟件工程基礎(chǔ),軟件工程,基礎(chǔ),全套,PPT,課件
展開閱讀全文
- 溫馨提示:
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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
裝配圖網(wǎng)所有資源均是用戶自行上傳分享,僅供網(wǎng)友學習交流,未經(jīng)上傳用戶書面授權(quán),請勿作他用。