軟件復(fù)用技術(shù)_第1頁(yè)
軟件復(fù)用技術(shù)_第2頁(yè)
軟件復(fù)用技術(shù)_第3頁(yè)
軟件復(fù)用技術(shù)_第4頁(yè)
軟件復(fù)用技術(shù)_第5頁(yè)
已閱讀5頁(yè),還剩13頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

軟件復(fù)用技術(shù)軟件復(fù)用技術(shù)軟件復(fù)用技術(shù)xxx公司軟件復(fù)用技術(shù)文件編號(hào):文件日期:修訂次數(shù):第1.0次更改批準(zhǔn)審核制定方案設(shè)計(jì),管理制度論使用復(fù)用設(shè)計(jì)1、引言復(fù)用是活動(dòng),而不是對(duì)象。在創(chuàng)建軟件相關(guān)的系統(tǒng)的語(yǔ)境中,復(fù)用僅僅是非常簡(jiǎn)單的任何過(guò)程,該過(guò)程通過(guò)復(fù)用來(lái)自以前開(kāi)發(fā)工作的某些東西來(lái)生產(chǎn)(或幫助生產(chǎn))一個(gè)系統(tǒng)。那么,唯一的問(wèn)題是:復(fù)用什么、什么是導(dǎo)致成功復(fù)用的過(guò)程。在軟件工程的范圍內(nèi),復(fù)用既是舊概念,也是新概念。程序員從最早的計(jì)算時(shí)代已開(kāi)始復(fù)用概念、對(duì)象、論據(jù)、抽象和過(guò)程,但是我們復(fù)用的途徑是特定的。本文對(duì)軟件復(fù)用的討論,將從以下四個(gè)方面進(jìn)行:1)軟件工程師可以獲得一系列可復(fù)用的軟件制品,這些包括軟件的技術(shù)表示(例如,規(guī)約、體系結(jié)構(gòu)模型、設(shè)計(jì)和代碼)、文檔、測(cè)試數(shù)據(jù),甚至包括過(guò)程相關(guān)的任務(wù)(如,檢查技術(shù))。2)復(fù)用過(guò)程包括兩個(gè)并發(fā)的子過(guò)程:領(lǐng)域工程和軟件工程。領(lǐng)域工程的目的是在特定應(yīng)用領(lǐng)域中標(biāo)識(shí)、構(gòu)造、分類(lèi)和傳播一組軟件制品。然后,軟件工程可在新系統(tǒng)開(kāi)發(fā)中選取這些軟件制品作為復(fù)用。3)構(gòu)件復(fù)用為軟件質(zhì)量、開(kāi)發(fā)者生產(chǎn)率、以及整個(gè)系統(tǒng)成本帶來(lái)了固有的收益,然而,在復(fù)用過(guò)程模型被廣泛地用于軟件產(chǎn)業(yè)前,必須克服很多障礙。4)對(duì)可復(fù)用構(gòu)件的分析、設(shè)計(jì)技術(shù)采用和在良好的軟件工程實(shí)踐中使用的相同原則和概念。可復(fù)用構(gòu)件應(yīng)該在一個(gè)環(huán)境中設(shè)計(jì),該環(huán)境為每個(gè)應(yīng)用領(lǐng)域建立標(biāo)準(zhǔn)數(shù)據(jù)結(jié)構(gòu)、接口協(xié)議和程序體系結(jié)構(gòu)。2、可復(fù)用的軟件制品軟件復(fù)用不僅僅涉及源代碼,但是,還涉及多少東西呢?CaperJones定義了可作為復(fù)用候選的十種軟件制品:項(xiàng)目計(jì)劃。軟件項(xiàng)目計(jì)劃的基本結(jié)構(gòu)和許多內(nèi)容(例如,SQA計(jì)劃)均是可以跨項(xiàng)目復(fù)用的。這樣減少了用于制定計(jì)劃的時(shí)間,也減低了和建立進(jìn)度表、風(fēng)險(xiǎn)分析和其他特征相關(guān)的不確定性。成本估計(jì)。因?yàn)榻?jīng)常不同項(xiàng)目中含有類(lèi)似的功能,所以有可能在極少修改或不修改的情況下,復(fù)用對(duì)該功能的成本估計(jì)。體系結(jié)構(gòu)。即使當(dāng)考慮不同的應(yīng)用領(lǐng)域時(shí),也很少有截然不同的程序和數(shù)據(jù)體系結(jié)構(gòu)。因此,有可能創(chuàng)建一組類(lèi)屬的體系結(jié)構(gòu)模板(例如,事務(wù)處理體系結(jié)構(gòu)),并將那些模板作為可復(fù)用的設(shè)計(jì)框架。需求模型和規(guī)約。類(lèi)和對(duì)象的模型和規(guī)約是明顯的復(fù)用的候選者,此外,用傳統(tǒng)軟件工程方法開(kāi)發(fā)的分析模型(例如,數(shù)據(jù)流圖)也是可復(fù)用的。設(shè)計(jì)。用傳統(tǒng)方法開(kāi)發(fā)的體系結(jié)構(gòu)、數(shù)據(jù)、接口和過(guò)程化設(shè)計(jì)是復(fù)用的候選者,更常見(jiàn)的是,系統(tǒng)和對(duì)象設(shè)計(jì)是可復(fù)用的。源代碼。驗(yàn)證過(guò)的程序構(gòu)件(用兼容的程序設(shè)計(jì)語(yǔ)言書(shū)寫(xiě)的)是復(fù)用的候選者。用戶和技術(shù)文檔。即使特定的應(yīng)用是不同的,也經(jīng)常有可能復(fù)用用戶和技術(shù)文檔的大部分。用戶界面??赡苁亲顝V泛被復(fù)用的軟件制品,GUI軟件經(jīng)常被復(fù)用。因?yàn)樗烧嫉揭粋€(gè)應(yīng)用的60%的代碼量,因此,復(fù)用的效果非常顯著。數(shù)據(jù)。在大多數(shù)經(jīng)常被復(fù)用的軟件制品中,數(shù)據(jù)包括:內(nèi)部表、列表和記錄結(jié)構(gòu),以及文件和完整的數(shù)據(jù)庫(kù)。測(cè)試用例。一旦設(shè)計(jì)或代碼構(gòu)件將被復(fù)用,相關(guān)的測(cè)試用例應(yīng)該“附屬于”它們。應(yīng)該注意,復(fù)用可以擴(kuò)展到上面所討論的可交付的軟件制品之外,它也包含了軟件工程過(guò)程中的元素。特定的分析建模方法、檢查技術(shù)、測(cè)試用例設(shè)計(jì)技術(shù)、質(zhì)量保證過(guò)程、以及很多其他軟件工程實(shí)踐可以被“復(fù)用”,例如,如果某軟件項(xiàng)目組有效地應(yīng)用凈室軟件工程方法,該方法可能適用于另一個(gè)項(xiàng)目。為了作出決定,有必要定義一組描述功能,它們使得潛在的凈室用戶能夠?qū)ζ鋺?yīng)用作出適當(dāng)?shù)臎Q策。3、復(fù)用過(guò)程復(fù)用過(guò)程包括兩個(gè)并發(fā)的子過(guò)程:領(lǐng)域工程和軟件工程。、領(lǐng)域工程領(lǐng)域工程的目的是標(biāo)識(shí)、構(gòu)造、分類(lèi)和傳播一組軟件制品,它們對(duì)某特定應(yīng)用領(lǐng)域中對(duì)現(xiàn)存的和未來(lái)的軟件系統(tǒng)具有很好適用性。其整體目標(biāo)是建立相應(yīng)的機(jī)制,以使得軟件工程師在工作于新的或現(xiàn)存的系統(tǒng)時(shí)可以分享這些軟件制品——復(fù)用它們。領(lǐng)域工程包括三個(gè)主要的活動(dòng)——分析、構(gòu)造和傳播。在第20章中已給出領(lǐng)域分析的概述,然而,本節(jié)中將再討論這個(gè)話題。領(lǐng)域構(gòu)造和傳播將在本章以后幾節(jié)中討論。有人爭(zhēng)辯說(shuō)“復(fù)用將消失,不是被消除,而是被集成”進(jìn)軟件工程實(shí)踐之中,隨著復(fù)用被更多的強(qiáng)調(diào),人們相信在下個(gè)十年領(lǐng)域工程將變得和軟件工程一樣重要。、領(lǐng)域分析過(guò)程在面向?qū)ο筌浖こ谭秶鷥?nèi)領(lǐng)域分析的方法,過(guò)程中的步驟定義如下:1).定義將被研究的領(lǐng)域。2).分類(lèi)從領(lǐng)域中抽出的物項(xiàng)。3).收集領(lǐng)域中有代表性的應(yīng)用樣本。4).分析樣本中的每個(gè)應(yīng)用。5).開(kāi)發(fā)對(duì)象的分析模型。必須注意,領(lǐng)域分析適用于任意軟件工程范型,并且可以用于傳統(tǒng)的以及面向?qū)ο蟮能浖_(kāi)發(fā)。Prieto-Diaz擴(kuò)展了上面給出的領(lǐng)域分析的第二個(gè)步驟,建議了一個(gè)8步驟的標(biāo)識(shí)和分類(lèi)可復(fù)用軟件制品的方法:1).選擇特定的功能/對(duì)象。2).抽象功能/對(duì)象。3).定義分類(lèi)法。4).標(biāo)識(shí)公共特征。5).標(biāo)識(shí)特定的關(guān)系。6).抽象關(guān)系。7).導(dǎo)出功能模型。8).定義領(lǐng)域語(yǔ)言。領(lǐng)域語(yǔ)言使得在領(lǐng)域中進(jìn)行應(yīng)用的規(guī)約及構(gòu)造成為可能。雖然上面的步驟提供了一個(gè)有用的領(lǐng)域分析模型,但是它沒(méi)有提供幫助決定哪些軟件制品是復(fù)用候選的有用的指南。Hutchinson和Hindley提出了下面一組實(shí)際的問(wèn)題,它們可以用作標(biāo)識(shí)可復(fù)用軟件構(gòu)件的指南:*構(gòu)件功能對(duì)未來(lái)的實(shí)現(xiàn)工作是需要的嗎?

*在領(lǐng)域中構(gòu)件功能的公共性怎樣?

*在領(lǐng)域中存在構(gòu)件功能的重復(fù)嗎?

*構(gòu)件是否依賴(lài)于硬件?

*在不同實(shí)現(xiàn)之間硬件是否保持不變?

*硬件細(xì)節(jié)可被移動(dòng)到另一個(gè)構(gòu)件嗎?

*設(shè)計(jì)為下面的實(shí)現(xiàn)進(jìn)行過(guò)足夠的優(yōu)化嗎?

*我們能夠?qū)⒁粋€(gè)不可復(fù)用的構(gòu)件參數(shù)化以使其變成可復(fù)用的嗎?

*構(gòu)件是否可以?xún)H僅經(jīng)過(guò)少許修改就能夠在很多實(shí)現(xiàn)中復(fù)用嗎?

*通過(guò)修改進(jìn)行復(fù)用是可行的嗎?

*某不可復(fù)用的構(gòu)件能夠通過(guò)被分解以產(chǎn)生一組可復(fù)用構(gòu)件嗎?

*針對(duì)復(fù)用的構(gòu)件分解是有效的嗎?

關(guān)于領(lǐng)域分析的深入討論不在本書(shū)范圍之內(nèi),更多的信息可見(jiàn)。、結(jié)構(gòu)建模和結(jié)構(gòu)點(diǎn)當(dāng)使用領(lǐng)域分析時(shí),分析員尋找在某領(lǐng)域中應(yīng)用間的重復(fù)模式。結(jié)構(gòu)化建模(Structuralmodeling)是一種基于模式的領(lǐng)域工程方法,應(yīng)用該方法的前提假設(shè)是:每個(gè)應(yīng)用領(lǐng)域有重復(fù)的模式(功能的、數(shù)據(jù)的和行為的),它們具有可復(fù)用的潛在可能。Pollak和Rissman描述結(jié)構(gòu)建模如下:結(jié)構(gòu)模型由少量的用于表明清晰的交互模式的結(jié)構(gòu)元素組成。使用結(jié)構(gòu)模型的系統(tǒng)的體系結(jié)構(gòu)通過(guò)多個(gè)由這些模型元素組成的東西來(lái)刻劃,這樣,在系統(tǒng)的體系結(jié)構(gòu)單元間的復(fù)雜交互可以用在這些少量元素間的簡(jiǎn)單交互模式來(lái)描述。每個(gè)應(yīng)用領(lǐng)域可用一個(gè)結(jié)構(gòu)模型來(lái)刻劃(例如,飛行器電子設(shè)備在細(xì)節(jié)上差異很大,但是在該領(lǐng)域的所有現(xiàn)代軟件具有相同的結(jié)構(gòu)模型),因此,結(jié)構(gòu)模型是一種體系結(jié)構(gòu)制品,它可以也應(yīng)該在領(lǐng)域內(nèi)所有應(yīng)用中被復(fù)用。McMahon描述結(jié)構(gòu)點(diǎn)(structurePoint)為:“在結(jié)構(gòu)模型中的一個(gè)獨(dú)特構(gòu)成物”,結(jié)構(gòu)點(diǎn)有三個(gè)顯著的特征:1).一個(gè)結(jié)構(gòu)點(diǎn)是一個(gè)抽象,它應(yīng)該有有限數(shù)量的實(shí)例。用面向?qū)ο蟮男性拋?lái)陳述,類(lèi)層次的規(guī)模應(yīng)是小的。此外,該抽象應(yīng)該在領(lǐng)域中所有應(yīng)用中不斷重現(xiàn),否則,用于驗(yàn)證、文檔化和傳播結(jié)構(gòu)點(diǎn)所需的努力不可能是成本合算的。2).管理結(jié)構(gòu)點(diǎn)的使用的規(guī)則應(yīng)該是容易理解的。此外,結(jié)構(gòu)點(diǎn)的接口應(yīng)該相當(dāng)簡(jiǎn)單。3).結(jié)構(gòu)點(diǎn)應(yīng)該通過(guò)隱藏所有包含在結(jié)構(gòu)點(diǎn)內(nèi)部的復(fù)雜性而實(shí)現(xiàn)信息隱蔽,這會(huì)減少整個(gè)系統(tǒng)可被感知的復(fù)雜性。作為把結(jié)構(gòu)點(diǎn)當(dāng)作系統(tǒng)的體系結(jié)構(gòu)模式的一個(gè)例子,考慮警報(bào)系統(tǒng)的軟件領(lǐng)域,該領(lǐng)域可能包含如SafeHome這樣簡(jiǎn)單的系統(tǒng),或如工業(yè)過(guò)程警報(bào)系統(tǒng)這樣復(fù)雜的系統(tǒng),然而,在每種情形,均可以遇到一組可以預(yù)測(cè)的結(jié)構(gòu)模式:*界面,使用戶能夠和系統(tǒng)交互。*范圍設(shè)置機(jī)制,允許用戶設(shè)置將被測(cè)度的參數(shù)的范圍。*傳感器管理機(jī)制,和所有的監(jiān)控傳感器通訊。*反應(yīng)機(jī)制,對(duì)傳感器管理系統(tǒng)提供的輸入作出反應(yīng)。*控制機(jī)制,使用戶能夠可以控制監(jiān)控執(zhí)行的方式。這些結(jié)構(gòu)點(diǎn)中的每一個(gè)被集成到一個(gè)領(lǐng)域體系結(jié)構(gòu)中。定義跨越一組不同的應(yīng)用領(lǐng)域的類(lèi)屬的結(jié)構(gòu)點(diǎn)是可能的:*應(yīng)用前端。GUI,包括所有菜單、面板、輸入和命令編輯設(shè)施。*數(shù)據(jù)庫(kù)。所有和應(yīng)用領(lǐng)域相關(guān)的對(duì)象的倉(cāng)庫(kù)。*計(jì)算引擎。操作數(shù)據(jù)的數(shù)值和非數(shù)值模型。*報(bào)告設(shè)施。產(chǎn)生所有種類(lèi)的輸出的功能。*應(yīng)用編輯器。根據(jù)用戶特定需要定制應(yīng)用的機(jī)制。結(jié)構(gòu)點(diǎn)已被建議作為在軟件成本估計(jì)中代碼行和功能點(diǎn)的替代物。4、構(gòu)件復(fù)用關(guān)于創(chuàng)建可復(fù)用的軟件并沒(méi)有任何神奇之處。抽象、隱蔽、功能獨(dú)立性、求精、以及結(jié)構(gòu)化程序設(shè)計(jì)等設(shè)計(jì)概念,連同面向?qū)ο蠓椒?、測(cè)試、SQA、以及正確性驗(yàn)證方法——所有均對(duì)可復(fù)用軟件構(gòu)件的創(chuàng)建有貢獻(xiàn)。本節(jié)中,我們將不重復(fù)討論這些話題,而是考慮特定于復(fù)用的問(wèn)題,它們是對(duì)完整的軟件工程實(shí)踐的補(bǔ)充。、為了復(fù)用的分析和設(shè)計(jì)數(shù)據(jù)、功能和行為模型(用一系列不同符號(hào)表示)可以被創(chuàng)建以描述特定應(yīng)用必須完成的任務(wù),書(shū)面的規(guī)約被用于描述這些模型并生成完整的需求描述。理想地,分析分析模型以確定模型中的那些指向現(xiàn)存的可復(fù)用軟件制品的元素。問(wèn)題是以能夠?qū)е隆耙?guī)約匹配”的形式從需求模型中抽取信息。Bellinzoni及其同事描述了一種針對(duì)面向?qū)ο笙到y(tǒng)的方法:構(gòu)件被在不同的抽象層次定義和存儲(chǔ)為規(guī)約、設(shè)計(jì)和實(shí)現(xiàn)類(lèi)——每個(gè)類(lèi)是來(lái)自以前應(yīng)用的某產(chǎn)品的工程化描述。規(guī)約知識(shí)——開(kāi)發(fā)知識(shí)——被以復(fù)用建議(reuse-suggestion)類(lèi)的形式存儲(chǔ),它們包括對(duì)以構(gòu)件的描述為基礎(chǔ)檢索可復(fù)用構(gòu)件及檢索后組裝和剪裁構(gòu)件的指導(dǎo)。使用自動(dòng)化工具瀏覽構(gòu)件庫(kù),以試圖匹配當(dāng)前規(guī)約中所標(biāo)記的需求和那些為現(xiàn)存可復(fù)用構(gòu)件(類(lèi))描述的需求。領(lǐng)域特征和關(guān)鍵詞被用于發(fā)現(xiàn)潛在的可復(fù)用構(gòu)件。如果規(guī)約匹配生成符合當(dāng)前應(yīng)用需要的構(gòu)件,設(shè)計(jì)者可從可復(fù)用構(gòu)件庫(kù)中提取這些構(gòu)件并將它們用于新系統(tǒng)的設(shè)計(jì)中。如果沒(méi)能找到設(shè)計(jì)構(gòu)件,軟件工程師必須應(yīng)用傳統(tǒng)的或面向?qū)ο蟮脑O(shè)計(jì)方法去創(chuàng)建它們。正是在這點(diǎn)——當(dāng)設(shè)計(jì)者開(kāi)始創(chuàng)建新的構(gòu)件時(shí)——應(yīng)該考慮為了復(fù)用的設(shè)計(jì)(DFR)。我們已經(jīng)提到過(guò),為了復(fù)用的設(shè)計(jì)需要軟件工程師應(yīng)用已有的設(shè)計(jì)概念和原則,但是,也必須考慮應(yīng)用領(lǐng)域的特征。Binder建議了作為為了復(fù)用的設(shè)計(jì)的基礎(chǔ)而應(yīng)該考慮的一系列關(guān)鍵問(wèn)題:標(biāo)準(zhǔn)數(shù)據(jù)。應(yīng)該研究應(yīng)用領(lǐng)域,并標(biāo)識(shí)出標(biāo)準(zhǔn)的全局?jǐn)?shù)據(jù)結(jié)構(gòu)(例如,文件結(jié)構(gòu)或完整的數(shù)據(jù)庫(kù)),那么所有設(shè)計(jì)構(gòu)件可以使用這些標(biāo)準(zhǔn)數(shù)據(jù)結(jié)構(gòu)來(lái)刻劃。標(biāo)準(zhǔn)接口協(xié)議。應(yīng)該建立三個(gè)層次的接口協(xié)議:模塊內(nèi)接口的本質(zhì)、外部的技術(shù)(非人)接口的設(shè)計(jì)、以及人機(jī)界面。程序模板。結(jié)構(gòu)模型可以作為新程序的體系結(jié)構(gòu)設(shè)計(jì)的模板。一旦已經(jīng)建立了標(biāo)準(zhǔn)數(shù)據(jù)、接口和程序模板,則設(shè)計(jì)者有了一個(gè)可在其中創(chuàng)建設(shè)計(jì)的框架。符合這個(gè)框架的新的構(gòu)件對(duì)以后的復(fù)用有更高的概率。、構(gòu)造方法和設(shè)計(jì)一樣,可復(fù)用軟件制品的構(gòu)造依賴(lài)于本書(shū)中其他地方已經(jīng)討論過(guò)的軟件工程方法,構(gòu)造可以使用傳統(tǒng)的第三代語(yǔ)言、第四代語(yǔ)言和代碼生成器、可視化程序設(shè)計(jì)技術(shù)、或更高級(jí)的工具來(lái)完成。更高級(jí)的構(gòu)造技術(shù)的一個(gè)有代表性例子是Netron公司開(kāi)發(fā)Frame技術(shù)Netron方法定義了一組自適應(yīng)的、稱(chēng)作Frame的類(lèi)屬構(gòu)件。和對(duì)象一樣,F(xiàn)rame封裝數(shù)據(jù)和操作,但是,它擴(kuò)展了對(duì)象的定義,它結(jié)合進(jìn)了使軟件工程師能夠通過(guò)選擇、刪除、修改或重復(fù)那些構(gòu)成該Frame的任意子構(gòu)件而對(duì)Frame進(jìn)行適應(yīng)性修改的機(jī)制??梢酝ㄟ^(guò)組裝來(lái)自Frame層次的構(gòu)件而構(gòu)造應(yīng)用。在該層次底部的Frame類(lèi)似于在因子化體系結(jié)構(gòu)中的工作者(worker)模塊,即,它們包含執(zhí)行低層系統(tǒng)功能(例如,操作系統(tǒng)交互、接口構(gòu)造、數(shù)據(jù)庫(kù)交互)的操作和數(shù)據(jù)結(jié)構(gòu);在Frame層次中層的Frame著重于和特定信息系統(tǒng)領(lǐng)域相關(guān)的功能(例如,事務(wù)處理、銀行業(yè)務(wù)、客戶服務(wù));在層次的頂部是“規(guī)約fream”,它的作用是作為“系統(tǒng)的主要藍(lán)圖和開(kāi)發(fā)者創(chuàng)建來(lái)定義系統(tǒng)的唯一的Frame”。、基于構(gòu)件的開(kāi)發(fā)當(dāng)復(fù)用占據(jù)了一個(gè)應(yīng)用開(kāi)發(fā)的主導(dǎo)地位時(shí),則構(gòu)造方法有時(shí)被稱(chēng)為基于構(gòu)件的開(kāi)發(fā)或構(gòu)件軟件。如我們已經(jīng)看到的,領(lǐng)域工程提供了基于構(gòu)件的開(kāi)發(fā)所需要的可復(fù)用構(gòu)件庫(kù)。這些可復(fù)用構(gòu)件中的某些是內(nèi)部開(kāi)發(fā)的,其他的可以從現(xiàn)存應(yīng)用中抽取的,還有一些可以從第三方獲取。但是,我們?nèi)绾蝿?chuàng)建一個(gè)具有一致結(jié)構(gòu)的構(gòu)件庫(kù)——它可以被一系列不同的內(nèi)部和外部源查詢(xún)并且還可以被集成進(jìn)在某應(yīng)用領(lǐng)域內(nèi)的任意系統(tǒng)?答案是對(duì)這樣的構(gòu)件的標(biāo)準(zhǔn)的采用。4個(gè)“體系結(jié)構(gòu)成分”將被用于實(shí)現(xiàn)基于構(gòu)件的開(kāi)發(fā):數(shù)據(jù)交換模型。應(yīng)該對(duì)所有的可復(fù)用構(gòu)件定義使得用戶和應(yīng)用間能夠交互和傳遞數(shù)據(jù)的機(jī)制(例如,拖和放、剪切和粘貼)。數(shù)據(jù)交換機(jī)制不僅應(yīng)允許人和軟件、構(gòu)件和構(gòu)件間的數(shù)據(jù)傳遞,而且也應(yīng)使得能夠在系統(tǒng)資源間進(jìn)行數(shù)據(jù)傳遞(例如,將一個(gè)文件拖到某打印機(jī)圖符上以實(shí)現(xiàn)輸出)。自動(dòng)化。應(yīng)實(shí)現(xiàn)一系列工具、宏和腳本為可復(fù)用構(gòu)件間的交互服務(wù)。結(jié)構(gòu)化存儲(chǔ)。包含在“復(fù)合文檔”中的異質(zhì)數(shù)據(jù)(例如,圖形數(shù)據(jù)、聲音、文本和數(shù)值數(shù)據(jù))應(yīng)該被作為單獨(dú)的數(shù)據(jù)結(jié)構(gòu)來(lái)組織和訪問(wèn),而不是作為一組分開(kāi)的文件?!敖Y(jié)構(gòu)化數(shù)據(jù)維持了嵌套結(jié)構(gòu)的一個(gè)描述性索引,使得應(yīng)用可以自由地進(jìn)行導(dǎo)航瀏覽以定位、創(chuàng)建或編輯個(gè)體數(shù)據(jù)內(nèi)容,就象終端用戶直接操作一樣”。底層對(duì)象模型。對(duì)象模型保證在不同平臺(tái)上用不同程序設(shè)計(jì)語(yǔ)言開(kāi)發(fā)的構(gòu)件可以互操作,即,對(duì)象必須能夠跨網(wǎng)絡(luò)進(jìn)行通信。為了達(dá)到這個(gè)目標(biāo),對(duì)象模型定義了構(gòu)件互操作標(biāo)準(zhǔn),該標(biāo)準(zhǔn)是語(yǔ)言獨(dú)立的,并使用接口定義語(yǔ)言(IDL)來(lái)定義。因?yàn)閺?fù)用對(duì)軟件產(chǎn)業(yè)的潛在影響非常巨大,一些主要的公司和產(chǎn)業(yè)聯(lián)盟已經(jīng)提出了對(duì)構(gòu)件軟件的建議標(biāo)準(zhǔn):OpenDoc。主要技術(shù)公司(包括IBM、Apple、和Novell)的一個(gè)聯(lián)盟已經(jīng)提出了復(fù)合文檔和構(gòu)件軟件的標(biāo)準(zhǔn)OPenDoc。該標(biāo)準(zhǔn)定義了為使得由某開(kāi)發(fā)者提供的構(gòu)件能夠和另一個(gè)開(kāi)發(fā)者提供的構(gòu)件相互操作而必須實(shí)現(xiàn)的服務(wù)、控制基礎(chǔ)設(shè)施、和體系結(jié)構(gòu)。OMG/CORBA。對(duì)象管理組織發(fā)布了公共對(duì)象請(qǐng)求代理體系結(jié)構(gòu)(OMG/CORBA)。一個(gè)對(duì)象請(qǐng)求代理(ORB)提供了一系列服務(wù),它們使得可復(fù)用構(gòu)件(對(duì)象)可以和其他構(gòu)件通信,而不管它們?cè)谙到y(tǒng)中的位置。當(dāng)用OMG/CORBA標(biāo)準(zhǔn)建立構(gòu)件時(shí),那些構(gòu)件在某系統(tǒng)內(nèi)的集成(沒(méi)有修改)可以得到保證。使用客戶/服務(wù)器的比喻,在客戶端應(yīng)用中的對(duì)象向ORB服務(wù)器請(qǐng)求一個(gè)或多個(gè)服務(wù),請(qǐng)求是通過(guò)IDL或在運(yùn)行時(shí)動(dòng)態(tài)地進(jìn)行的。一個(gè)接口池包含了所有關(guān)于服務(wù)請(qǐng)求和回答格式的信息。。微軟開(kāi)發(fā)了一個(gè)構(gòu)件對(duì)象模型(COM),它提供了對(duì)在單個(gè)應(yīng)用中使用不同廠商生產(chǎn)的對(duì)象的規(guī)約。對(duì)象連接和嵌入(OLE)是COM的一部分,定義了可復(fù)用構(gòu)件的標(biāo)準(zhǔn)結(jié)構(gòu)。OLE已成為微軟操作系統(tǒng)(Windows95、WindowsNT)的一部分。這些標(biāo)準(zhǔn)中哪一個(gè)將在產(chǎn)業(yè)中占據(jù)支配地位?這在當(dāng)前是不容易回答的問(wèn)題。當(dāng)前OLE被用得更廣一些(由于基于Windows應(yīng)用的廣泛使用),但是,很多OMG/CORBA工具和開(kāi)發(fā)環(huán)境正在被引入。5、分類(lèi)和檢索構(gòu)件考慮一個(gè)大的大學(xué)圖書(shū)館,成千上萬(wàn)的書(shū)籍、期刊和其他信息資源是可用的。但是為了訪問(wèn)這些資源,必須有合適的分類(lèi)模式。為了在這些大量的信息中導(dǎo)航瀏覽,圖書(shū)館管理者定義了一種分類(lèi)模式,它包括分類(lèi)碼、關(guān)鍵詞、作者名、以及其他索引條目,所有這些使得用戶可以快速和方便地找到所需資源。現(xiàn)在考慮一個(gè)大的構(gòu)件倉(cāng)庫(kù),其中存放了成千上萬(wàn)的可復(fù)用構(gòu)件。但是,軟件工程師如何找到他所需要的構(gòu)件呢為了回答這個(gè)問(wèn)題,又出現(xiàn)了另一個(gè)問(wèn)題:我們?nèi)绾我詿o(wú)二義的、可分類(lèi)的術(shù)語(yǔ)來(lái)描述軟件構(gòu)件這些是困難的問(wèn)題,至今還沒(méi)有確定性的答案。在本節(jié)中,我們探討當(dāng)前的研究方向,這將使得未來(lái)的軟件工程師可以導(dǎo)航瀏覽復(fù)用庫(kù)。、描述可復(fù)用構(gòu)件可以用很多方式來(lái)描述可復(fù)用軟件構(gòu)件,但是理想的描述包括TracZ提出的3C模型——概念(concePt)、內(nèi)容(content)和語(yǔ)境(context)。軟件構(gòu)件的概念是“對(duì)構(gòu)件做什么的描述”。構(gòu)件的接口被完整地描述,而且語(yǔ)義——表示在前置條件后置條件的語(yǔ)境中——被標(biāo)識(shí)。概念將傳達(dá)構(gòu)件的意圖。構(gòu)件的內(nèi)容描述概念如何被實(shí)現(xiàn)。在本質(zhì)上,內(nèi)容是對(duì)一般用戶隱蔽的信息,只有那些企圖修改該構(gòu)件的人才需要了解的信息。語(yǔ)境將可復(fù)用軟件構(gòu)件放置到其應(yīng)用的領(lǐng)域中。即,通過(guò)刻劃概念的、操作的和實(shí)現(xiàn)的特征,語(yǔ)境使得軟件工程師能夠發(fā)現(xiàn)適當(dāng)?shù)臉?gòu)件以滿足應(yīng)用需求。為了可用在實(shí)際環(huán)境中,概念、內(nèi)容和語(yǔ)境必須被轉(zhuǎn)換為具體的規(guī)約模式。已有很多的文章涉及可復(fù)用構(gòu)件的分類(lèi)模式。所提出的方法可以分為三大類(lèi):圖書(shū)館和信息科學(xué)方法、人工智能方法、以及超文本系統(tǒng)。目前為止,絕大部分研究工作建議使用圖書(shū)館科學(xué)方法進(jìn)行構(gòu)件分類(lèi)。大多數(shù)軟件構(gòu)件分類(lèi)模式可歸為如下的三類(lèi):1)枚舉分類(lèi)(EnumeratedClassification)。通過(guò)定義一個(gè)層次結(jié)構(gòu)來(lái)描述構(gòu)件,在該層次中定義軟件構(gòu)件的類(lèi)以及不同層次的子類(lèi)。實(shí)際的構(gòu)件被羅列在枚舉層次的任何路徑的最低層,例如,對(duì)窗口操作的枚舉層次可能是:windowoperationsdisplayopenmenu-basedOpenWindowsystem-basedsysWindowcloseviapointer…resizeviacommandsetWindowSize,stdResize,shrinkwindowviadragpullwindow,stretchWindowup/downshuffle…move…close…枚舉分類(lèi)模式的層次結(jié)構(gòu)使得它易于理解和使用,然而,在建立層次之前,必須進(jìn)行領(lǐng)域工程以獲得在層次中適當(dāng)?shù)捻?xiàng)的足夠的信息。刻面分類(lèi)(FacetedClassification)。分析領(lǐng)域,并標(biāo)識(shí)出一組基本的描述特征,這些特征,稱(chēng)為刻面,被根據(jù)其重要性區(qū)分優(yōu)先次序并被聯(lián)系到構(gòu)件??堂婵梢悦枋鰳?gòu)件執(zhí)行的功能、被操作的數(shù)據(jù)、構(gòu)件應(yīng)用的語(yǔ)境或任意其他特征。描述構(gòu)件的刻面的集合稱(chēng)為刻面描述子,通常,刻面描述被限定不超過(guò)7或8個(gè)刻面。作為一個(gè)簡(jiǎn)單的在構(gòu)件分類(lèi)中使用刻面的例子,考慮使用下列構(gòu)件描述子的模式:{function,objecttype,systemtyPe}刻面描述子中的每個(gè)刻面可含有一個(gè)或多個(gè)值,這些值一般是描述性關(guān)鍵詞,例如,如果功能(function)是某構(gòu)件的刻面,賦給此刻面的典型值可能是:function=(copy,from)or(copy,replace,all)多個(gè)刻面值的使用使得原函數(shù)copy能夠被更完全地精化。關(guān)鍵詞(值)被賦給復(fù)用庫(kù)中的每個(gè)構(gòu)件的刻面集,當(dāng)軟件工程師在設(shè)計(jì)中希望查詢(xún)構(gòu)件庫(kù)以發(fā)現(xiàn)可能的構(gòu)件時(shí),規(guī)定一列值,然后到庫(kù)中尋找匹配項(xiàng)。可使用自動(dòng)工具以完成同義詞詞典功能,這使得查找不僅包括軟件工程師給出的關(guān)鍵詞,還包括這些關(guān)鍵詞的技術(shù)同義詞??堂娣诸?lèi)模式給領(lǐng)域工程師在刻劃構(gòu)件的復(fù)雜描述子時(shí)更大的靈活性,因?yàn)榭梢院苋菀椎丶尤胄碌目堂嬷?,因此,刻面分?lèi)模式比枚舉分類(lèi)方法易于擴(kuò)展和進(jìn)行適應(yīng)性修改。屬性—值分類(lèi)(Attribute-ValueClassification)。為領(lǐng)域中的所有構(gòu)件定義一組屬性,然后值被以和刻面分類(lèi)方法非常相似的方式賦給這些屬性,事實(shí)上,屬性-值分類(lèi)方法和刻面分類(lèi)方法是類(lèi)似的,除了下面幾點(diǎn)不同:(1)對(duì)可使用的屬性數(shù)量沒(méi)有限制,(2)屬性沒(méi)有優(yōu)先級(jí),(3)不使用同義詞詞典功能?;趯?duì)上面分類(lèi)技術(shù)的實(shí)驗(yàn)研究,F(xiàn)rank和Pole指出沒(méi)有明顯“最好”的技術(shù)和“沒(méi)有某種方法比別的方法在查找效果上更適度…”。對(duì)復(fù)用庫(kù)有效的分類(lèi)模式的開(kāi)發(fā)仍有許多工作要做。、構(gòu)件復(fù)用環(huán)境軟件構(gòu)件復(fù)用必須有環(huán)境的支撐,環(huán)境應(yīng)包含如下元素:*用于存儲(chǔ)構(gòu)件和對(duì)檢索構(gòu)件必需的分類(lèi)信息的構(gòu)件庫(kù)。*提供對(duì)構(gòu)件庫(kù)訪問(wèn)的庫(kù)管理系統(tǒng)。*允許客戶應(yīng)用從構(gòu)件庫(kù)服務(wù)器中檢索構(gòu)件和服務(wù)的軟件構(gòu)件檢索系統(tǒng)(如,對(duì)象請(qǐng)求代理)。*將復(fù)用的構(gòu)件集成到新設(shè)計(jì)或?qū)崿F(xiàn)中的CASE工具。每一個(gè)功能在復(fù)用庫(kù)的范圍內(nèi)交互或者被包含在復(fù)用庫(kù)中。復(fù)用庫(kù)是一個(gè)更大型CASE倉(cāng)庫(kù)的一個(gè)元素,并且為一系列可復(fù)用軟件制品(例如,規(guī)約、設(shè)計(jì)、代碼、測(cè)試用例、用戶指南)的存儲(chǔ)提供設(shè)施。復(fù)用庫(kù)包含一個(gè)數(shù)據(jù)庫(kù)以及查詢(xún)數(shù)據(jù)庫(kù)和構(gòu)件檢索所必需的工具,構(gòu)件分類(lèi)模式是構(gòu)件庫(kù)查詢(xún)的基礎(chǔ)。查詢(xún)通常用前面描述的3C模型中的語(yǔ)境來(lái)刻劃,如果某初始查詢(xún)產(chǎn)生大

溫馨提示

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

評(píng)論

0/150

提交評(píng)論