面向方面的實(shí)時(shí)系統(tǒng)開發(fā)方法郭東亮畢業(yè)論文最終稿_第1頁
面向方面的實(shí)時(shí)系統(tǒng)開發(fā)方法郭東亮畢業(yè)論文最終稿_第2頁
面向方面的實(shí)時(shí)系統(tǒng)開發(fā)方法郭東亮畢業(yè)論文最終稿_第3頁
面向方面的實(shí)時(shí)系統(tǒng)開發(fā)方法郭東亮畢業(yè)論文最終稿_第4頁
面向方面的實(shí)時(shí)系統(tǒng)開發(fā)方法郭東亮畢業(yè)論文最終稿_第5頁
已閱讀5頁,還剩64頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、廣東工業(yè)大學(xué)工學(xué)碩士學(xué)位論文面向方面的實(shí)時(shí)系統(tǒng)開發(fā)方法郭東亮二零零五年四月三十日分類號(hào): 學(xué)校代碼:11911udc: 密級(jí): 學(xué) 號(hào):2110205159廣東工業(yè)大學(xué)學(xué)位論文面向方面的實(shí)時(shí)系統(tǒng)開發(fā)方法郭東亮指 導(dǎo) 教 師: 張立臣 教授 廣東工業(yè)大學(xué)計(jì)算機(jī)學(xué)院學(xué) 科 門 類: 工學(xué) 專 業(yè) 名 稱: 計(jì)算機(jī)軟件與理論 申請(qǐng)學(xué)位級(jí)別: 碩 士 論文提交日期: 2005 年 4 月 論文答辯日期: 2005 年 5 月 學(xué)位授予單位: 廣東工業(yè)大學(xué) 摘要現(xiàn)代軟件開發(fā)都要把整個(gè)系統(tǒng)按功能分解為小的單元,然后開發(fā)這些小單元,這些小的單元隱藏內(nèi)部實(shí)現(xiàn),對(duì)外提供接口,最后組合這些單元為整個(gè)系統(tǒng),實(shí)現(xiàn)整個(gè)

2、系統(tǒng)的功能。但是系統(tǒng)中有的方面是橫切整個(gè)系統(tǒng)的非功能關(guān)注點(diǎn),無法很好地封裝在單個(gè)模塊中。如日志、性能問題、安全、上下文相關(guān)錯(cuò)誤處理、qos監(jiān)測(cè)等等,這些方面分散在整個(gè)系統(tǒng)中,并且與系統(tǒng)的功能代碼糾纏在一起,這樣降低了模塊的可追蹤性、模塊的可重用性、系統(tǒng)的可維護(hù)性等一系列問題,所以需要分離并模塊化這些非功能關(guān)注點(diǎn)。面向方面編程在實(shí)現(xiàn)上分離和模塊化橫切關(guān)注點(diǎn),面向方面建模在軟件開發(fā)的其它階段用一致的方法來詳述、可視化、構(gòu)造和文檔化方面相關(guān)制品,這樣在整個(gè)軟件開發(fā)過程可以使用面向方面技術(shù)。實(shí)時(shí)系統(tǒng)是面向方面技術(shù)很好的應(yīng)用場(chǎng)所,因?yàn)樵趯?shí)時(shí)系統(tǒng)中,有很多非功能需求,且這些非功能需求往往橫切整個(gè)系統(tǒng)。在實(shí)

3、時(shí)系統(tǒng)中關(guān)鍵的就是時(shí)間要求了,這些時(shí)間要求散布在整個(gè)系統(tǒng)的功能部件里,帶來了代碼混亂和代碼分散問題。本文分析介紹了aspectj、組合過濾器、多維關(guān)注點(diǎn)分離和自適應(yīng)編程等典型的分離關(guān)注點(diǎn)的方法。比較完整的介紹了面向方面建模領(lǐng)域的研究。闡述了實(shí)時(shí)系統(tǒng)中的主要實(shí)時(shí)需求,以及與實(shí)時(shí)系統(tǒng)有關(guān)的uml框架集。提出了一個(gè)新的擴(kuò)展uml進(jìn)行面向方面建模的方法,它以合適的語義表達(dá)了aspectj和aspectc+的元素和織入機(jī)制。在這個(gè)方法中,方面繼承自類,切入點(diǎn)和通知繼承自特征,這樣切入點(diǎn)和通知是方面的一部分,方面與基本類的關(guān)系用橫切依賴表示。切入點(diǎn)的圖符可以表達(dá)多個(gè)方面在相同連接點(diǎn)的橫切行為,通知以一致的

4、方式建模結(jié)構(gòu)橫切和行為橫切,通過在順序圖上新加一個(gè)通知發(fā)出焦點(diǎn),并將通知表示為消息,這樣可以清晰建模通知在何時(shí)何處怎樣影響系統(tǒng)的行為。并分析了如何將這個(gè)方法應(yīng)用于實(shí)時(shí)系統(tǒng)開發(fā)。關(guān)鍵詞:面向方面編程;面向方面軟件開發(fā);實(shí)時(shí)系統(tǒng);umlabstractusing modern software development methodology, developers first decompose system into small units, which hide the internal implementation and provide only external interfaces,

5、then implement these units, at last compose these units to get a full system and realize required functions. but there are some non-functional concerns which crosscut whole system and cant be well encapsulated into a single module, such as logging, performance analysis, security, context related err

6、or handling, qos monitoring, etc. these aspects are scattered and tangled in whole system, decreasing software traceability, reusability, adaptability. so these non-functional concerns should be separated and modularized.aspect-oriented programming (aop) separates and modularizes crosscutting concer

7、ns at implementation stage. aspect-oriented modeling (aom) specifies, visualizes, constructs and documents aspect related artifacts in a consistent way at other stage of software development. thus whole software development process can use aspect-oriented technique.real-time systems are well places

8、to apply aspect-oriented technique, for there are lots of non-functional requirements in real-time system, which scattering in whole system. the codes related with timing are mixed with other codes, resulting in code scattering and tangling.this article considers various techniques to separate cross

9、cutting concerns, namely aspectj, aspectc+, composition filters, hyperspace and adaptive programming; summarizes the researches in aom domain; analyses real-time systems timing requirements and uml profiles for real-time systems.this article proposes a new technique to modeling aspect-oriented const

10、ructs and mechanisms by extending uml, which can represent constructs and weaving mechanism of aspectj and aspectc+ with appropriate semantics. in this method, aspect is subclass of class; pointcut and advice are derived from feature, thus pointcut and advice are parts of aspect; relationship betwee

11、n aspects and base class is represented by special crosscut dependency. the notation of pointcut can express crosscutting behavior of many aspects at same join point. advice can model structural crosscutting and behavior crosscutting in a uniform way. by adding a new block, advice sending focus, in

12、sequence diagram and regard advice as message, this method can clearly model where and when and how advices affect system behavior. the article also examines how this technique can be practiced in real-time systems development.keywords: aop;aosd;real-time systems;uml目錄摘要iabstractii目錄vcontentsvii第一章

13、緒論11.1 研究背景11.2研究意義21.3面向方面技術(shù)在實(shí)時(shí)系統(tǒng)中的應(yīng)用31.4 研究內(nèi)容4第二章 分離關(guān)注點(diǎn)的方法52.1 aspectj52.2 aspectc+72.3 組合過濾器82.4 hyperspace132.4.1 多維關(guān)注點(diǎn)分離132.4.2 hyperspace152.4.3 hyper/j162.5自適應(yīng)編程17第三章 實(shí)時(shí)系統(tǒng)軟件設(shè)計(jì)213.1 實(shí)時(shí)系統(tǒng)概念213.2 實(shí)時(shí)需求213.3 實(shí)時(shí)uml擴(kuò)展233.3.1 通用資源建模253.3.2 通用時(shí)間建模303.4 實(shí)時(shí)系統(tǒng)建模工具34第四章 面向方面建模354.1 uml的擴(kuò)展機(jī)制354.2 表示連接點(diǎn)364.

14、3用況實(shí)現(xiàn)模塊化364.4用uml進(jìn)行面向方面建模37第五章 實(shí)時(shí)方面建模395.1 aop元素表示395.1.1表示切入點(diǎn)395.1.2表示通知與引入405.1.3 表示方面415.2 舉例415.3 用況實(shí)現(xiàn)模塊化445.4 在類圖中加入方面455.5在順序圖中加入方面475.6 其它50結(jié)論51參考文獻(xiàn)53攻讀碩士學(xué)位期間發(fā)表的論文58獨(dú)創(chuàng)性聲明59致謝61contentsabstractiicontentsviichapter1 introduction11.1 background11.2 necessity21.3 aspect-oriented technique in real

15、-time systems31.4 structure of this thesis4chapter2 approaches to separate concerns52.1 aspectj52.2 aspectc+72.3 composition filters82.4 hyperspace132.4.1 mdsoc132.4.2 hyperspace152.4.3 hyper/j162.5 adaptive programming17chapter3 real-time systems software design213.1 concepts of real-time system213

16、.2 timing requirements213.3 uml extension for real-time system233.3.1 general resource modeling253.3.2 general timing modeling303.4 tools for real-time system modeling34chapter4 aspect-oriented modeling354.1 uml extension mechanism354.2 join point representation364.3 use case modularity using aosd36

17、4.4 aspect-oriented modeling using uml37chapter5 real-time aspect modeling395.1 modeling constructs of aop395.1.1 modeling pointcut395.1.2 modeling advice and introduction405.1.3 modeling aspect415.2 example415.3 modularizing implementation of use case445.4 adding aspect to class diagram455.5 adding

18、 aspect to sequence diagram475.6 others50summary and future work51bibliography53publications during masters studies58statement of originality59acknowledgments61第一章 緒論1.1 研究背景軟件開發(fā)思想就是抽象與分解,從過程化、結(jié)構(gòu)化分解編程,到現(xiàn)在主流的面向?qū)ο缶幊?,開發(fā)典范(paradigm)發(fā)生了很大變化,唯一不變的就是抽象與分解的思想,只是抽象的種類和質(zhì)量、分解的方法發(fā)生了變化。當(dāng)前,面向?qū)ο缶幊蹋╫op)1和基于組件的軟件開發(fā)得

19、到了廣泛的使用,面向?qū)ο蠹夹g(shù)能夠很好地將現(xiàn)實(shí)世界領(lǐng)域中的實(shí)體和它的行為建模為抽象的對(duì)象。系統(tǒng)變成一系列相互協(xié)作的對(duì)象,類的封裝性隱藏了實(shí)現(xiàn)的細(xì)節(jié);類的繼承性實(shí)現(xiàn)了重用;多態(tài)性使得不同對(duì)象接收到相同消息時(shí)產(chǎn)生不同的動(dòng)作。確實(shí),oop表明了它處理復(fù)雜問題的能力,但是oop無法模塊化橫切(crosscut)整個(gè)系統(tǒng)的關(guān)注點(diǎn)(concern),這些關(guān)注點(diǎn)稱為橫切關(guān)注點(diǎn)(crosscutting concerns),如時(shí)間要求、安全、qos監(jiān)測(cè)、日志等等。這些非功能單元彌散在整個(gè)系統(tǒng)中,導(dǎo)致了代碼分散(code scattering);并且與功能單元混雜在一起,導(dǎo)致了代碼糾纏(code tangling

20、)。這樣降低了程序的可理解性、適應(yīng)性、可維護(hù)性和可復(fù)用性。oop中用混入類來處理橫切,但是基本類需要顯式調(diào)用混入對(duì)象的方法,即操作的邏輯由基本類控制,且好的系統(tǒng)設(shè)計(jì)師要考慮當(dāng)前和將來可能的需求以避免打補(bǔ)丁,但是預(yù)知將來的需求是困難的,這樣系統(tǒng)設(shè)計(jì)師陷入了“應(yīng)該寧可設(shè)計(jì)不足還是寧可過分設(shè)計(jì)”的兩難境地。其它解決方法如行為型設(shè)計(jì)模式也是由基本類控制操作邏輯,面向特定領(lǐng)域的解決方式(如框架)僅提供這個(gè)領(lǐng)域的處理關(guān)注點(diǎn)的方式,所以屬于這個(gè)領(lǐng)域外的關(guān)注點(diǎn)需要特殊處理。解決問題需要分離關(guān)注點(diǎn),將不同的關(guān)注點(diǎn)分離成模塊,而這些模塊可以單獨(dú)實(shí)現(xiàn)。這樣開發(fā)功能模塊時(shí)無需要考慮非功能需求,在功能模塊里不出現(xiàn)非功能

21、代碼;各個(gè)非功能模塊也單獨(dú)實(shí)現(xiàn)。系統(tǒng)有信息描述如何將這些模塊可控地組合起來形成結(jié)構(gòu)和行為明確的系統(tǒng)。系統(tǒng)信息主要描述了在何處非功能模塊影響其他模塊的結(jié)構(gòu)和行為,有的方法將這些信息包含在非功能模塊里,有的方法將這些信息放在配置文件內(nèi)。通過分離關(guān)注點(diǎn),開發(fā)人員可以只關(guān)注感興趣的部分。并且當(dāng)需求改變后,只需修改受影響的模塊,而這些模塊往往只在一處出現(xiàn),這樣避免了在整個(gè)程序內(nèi)修改。已經(jīng)有很多分離關(guān)注點(diǎn)的方法,這些方法可以統(tǒng)稱為面向方面編程(aop, aspect oriented programming)2,雖然在這個(gè)概念提出之前,已經(jīng)有很多這方面的研究。面向方面編程將關(guān)注點(diǎn)實(shí)現(xiàn)為分離的方面,然而實(shí)現(xiàn)

22、僅僅是軟件開發(fā)過程中的一個(gè)階段?,F(xiàn)在已經(jīng)開始研究在需求、設(shè)計(jì)等其他開發(fā)階段如何有效地分離關(guān)注點(diǎn),目標(biāo)是要在整個(gè)軟件開發(fā)過程應(yīng)用面向方面技術(shù),從而形成面向方面的軟件開發(fā)(aosd, aspect oriented software development)。這些研究主要集中在如何擴(kuò)展uml3使其支持面向方面技術(shù)?,F(xiàn)在面向方面編程還在研究過程中,面向方面的軟件開發(fā)方法的研究也剛剛起步,但是它們代表了未了軟件開發(fā)的方向,grady booch預(yù)言aop將崛起4。1.2研究意義實(shí)時(shí)嵌入式設(shè)備被廣泛使用在現(xiàn)代生活中,實(shí)時(shí)控制系統(tǒng)是現(xiàn)代化生產(chǎn)的保證,復(fù)雜的實(shí)時(shí)系統(tǒng)在國防現(xiàn)代化建設(shè)中發(fā)揮越來越重要的作用。這

23、些系統(tǒng)廣泛應(yīng)用在對(duì)時(shí)間有較高要求的環(huán)境中,如汽車,飛機(jī),核反應(yīng)堆等的控制中,這些系統(tǒng)的失敗輕則導(dǎo)致經(jīng)濟(jì)財(cái)產(chǎn)損失,重則生命丟失。實(shí)時(shí)系統(tǒng)是面向方面很好的應(yīng)用場(chǎng)所,因?yàn)樵趯?shí)時(shí)系統(tǒng)中,有很多非功能需求,且這些非功能需求往往橫切整個(gè)系統(tǒng)。在實(shí)時(shí)系統(tǒng)中關(guān)鍵的就是時(shí)間要求了,如果系統(tǒng)沒有在給定的時(shí)間里完成任務(wù),任務(wù)是失敗的,這些時(shí)間要求散布在整個(gè)系統(tǒng)的功能部件里,帶來了前述的代碼混亂和代碼分散問題,導(dǎo)致系統(tǒng)代碼不易讀,不易修改,易產(chǎn)生不一致,重用性差,不易修改和升級(jí)等一系列問題。實(shí)時(shí)系統(tǒng)的一個(gè)重要特點(diǎn)就是要求系統(tǒng)具有可預(yù)報(bào)性,要判斷是否調(diào)度是可行的,這需要收集系統(tǒng)當(dāng)前信息和qos信息,追蹤系統(tǒng)執(zhí)行情況,這

24、些代碼也混在功能部件里。實(shí)時(shí)系統(tǒng)是高可靠性的系統(tǒng),軟實(shí)時(shí)系統(tǒng)(soft real-time system)任務(wù)的失敗會(huì)使系統(tǒng)性能降低,但是有些安全關(guān)鍵(safety-critical)的硬實(shí)時(shí)系統(tǒng)(hard real-time system)的失敗將會(huì)帶來災(zāi)難性的后果,如核反應(yīng)堆控制系統(tǒng),武器控制系統(tǒng)等,這些系統(tǒng)的失敗將會(huì)有生命的代價(jià)。但是系統(tǒng)故障是不可避免的,因?yàn)橛布蛙浖豢赡茉O(shè)計(jì)的完全正確,所以實(shí)時(shí)系統(tǒng)需要容錯(cuò),這樣一個(gè)系統(tǒng)里的容錯(cuò)代碼也彌漫在整個(gè)系統(tǒng)中,導(dǎo)致前述問題。實(shí)時(shí)嵌入式系統(tǒng)也有安全上的需求,以防止非授權(quán)用戶的進(jìn)入,同樣這些非功能性代碼也會(huì)彌漫在整個(gè)系統(tǒng)中。為了提高性能和達(dá)到可預(yù)

25、報(bào)性,實(shí)時(shí)系統(tǒng)需要特別的資源管理策略,如為了可預(yù)報(bào)性,不使用緩存和虛存機(jī)制,因?yàn)槿表摃?huì)導(dǎo)致時(shí)間不可預(yù)報(bào)。另外為了提高系統(tǒng)性能,需要對(duì)內(nèi)存進(jìn)行管理,這些管理策略會(huì)彌漫在整個(gè)功能部件里。所以有必要把這些非功能代碼從功能部件里分離出來。分別編寫功能部件和非功能方面,然后把它們組合在一起。實(shí)時(shí)系統(tǒng)在社會(huì)和國家生活中應(yīng)用越來越廣泛,影響也越來越大,系統(tǒng)也越來越復(fù)雜。根據(jù)上述實(shí)時(shí)系統(tǒng)特點(diǎn)和面向方面開發(fā)的特點(diǎn),可以得出把面向方面技術(shù)應(yīng)用到實(shí)時(shí)系統(tǒng)開發(fā)中很有必要。1.3面向方面技術(shù)在實(shí)時(shí)系統(tǒng)中的應(yīng)用研究者已經(jīng)開始探索如何將面向方面技術(shù)應(yīng)用在實(shí)時(shí)系統(tǒng)中。在實(shí)時(shí)系統(tǒng)和嵌入式系統(tǒng)中建立了一些模型5,6。5提出了ac

26、cord(aspectual component-based real-time system development)設(shè)計(jì)方法,也提出了一個(gè)rtcom(real-time component model)模型。使用accord開發(fā)實(shí)時(shí)系統(tǒng)的過程是:第一階段把把實(shí)時(shí)系統(tǒng)按功能和低耦合高內(nèi)聚的要求分解為一系列的組件;第二階段把實(shí)時(shí)系統(tǒng)分解為一系列的方面,方面橫切組件和整個(gè)系統(tǒng),這個(gè)階段處理非功能需求和橫切關(guān)注點(diǎn);最后按rtcom實(shí)現(xiàn)組件和方面。rtcom允許把方面編織到組件里,包括三部分:(1)功能部分;(2)運(yùn)行時(shí)系統(tǒng)依賴部分;(3)組合部分。另外把方面分為三類:(1)應(yīng)用程序方面;(2)運(yùn)行

27、時(shí)方面;(3)組合方面。嵌入式系統(tǒng)的一個(gè)重要特征是依賴環(huán)境。6提出了一個(gè)對(duì)嵌入式系統(tǒng)進(jìn)行面向方面的環(huán)境建模方法。7把面向方面編程技術(shù)應(yīng)用到實(shí)時(shí)操作系統(tǒng)開發(fā)上。因?yàn)樵趯?shí)時(shí)操作系統(tǒng)里有許多橫切的特征,為了滿足日益增長的對(duì)實(shí)時(shí)操作系統(tǒng)快速定制的要求,需要面向方面編程技術(shù),這里把函數(shù)看成一系列的基本塊,基本塊的功能代碼可由不同的方面提供,這樣橫切了函數(shù),且這些基本塊可視,提供了圖形表示的開發(fā)框架;支持類的組裝,不同方面里的相同的類可以組成一個(gè)大類。8展示了如何把面向方面技術(shù)應(yīng)用的分布式實(shí)時(shí)系統(tǒng)上。分布式實(shí)時(shí)系統(tǒng)中的非功能需求可以用方面來表達(dá),這篇文章給出了一個(gè)把分布性、時(shí)間要求和容錯(cuò)方面加入到一個(gè)簡單

28、的日志組件里的方法。9,10把面向方面應(yīng)用到disco(distributed co-operation)系統(tǒng)中,disco 是描述反應(yīng)式系統(tǒng)的形式化規(guī)格說明方法。1.4 研究內(nèi)容本文比較完整地分析介紹了分離和模塊化關(guān)注點(diǎn)的方法,以及面向方面社區(qū)對(duì)面向方面建模的研究;闡述了實(shí)時(shí)系統(tǒng)中實(shí)時(shí)需求的主要概念和建模方法;提出了一個(gè)新的通過擴(kuò)展uml進(jìn)行面向方面建模的方法,并將這個(gè)方法應(yīng)用于實(shí)時(shí)系統(tǒng)開發(fā)。論文結(jié)構(gòu)安排如下:第一章介紹了面向方面編程可以模塊化非功能關(guān)注點(diǎn);分析了實(shí)時(shí)系統(tǒng)中的非功能關(guān)注點(diǎn)以及實(shí)時(shí)系統(tǒng)中使用面向方面技術(shù)的現(xiàn)狀。第二章介紹了典型的分離關(guān)注點(diǎn)的方法。第三章闡述了實(shí)時(shí)系統(tǒng)中的實(shí)時(shí)需求

29、,以及用uml建模實(shí)時(shí)系統(tǒng)的方法。第四章分析介紹了面向方面社區(qū)對(duì)面向方面建模的研究。第五章提出了一個(gè)新的擴(kuò)展uml來表達(dá)面向方面中的元素和機(jī)制,闡述如何將這種方法應(yīng)用于實(shí)時(shí)系統(tǒng)開發(fā)中。第二章 分離關(guān)注點(diǎn)的方法系統(tǒng)中的非功能需求往往橫切整個(gè)系統(tǒng),傳統(tǒng)的結(jié)構(gòu)化方法以及現(xiàn)代流行的面向?qū)ο蠓椒o法很好地模塊化這些非功能需求,導(dǎo)致了實(shí)現(xiàn)非功能需求代碼的分散和與功能代碼糾纏在一起,造成代碼量急劇增加,開發(fā)效率低,可讀性差,極易引起不一致等問題,所以需要分離這些非功能關(guān)注點(diǎn)。對(duì)于如何有效的分離關(guān)注點(diǎn),人們已經(jīng)提出了很多方法。如aspectj、組合過濾器、多維關(guān)注點(diǎn)分離和自適應(yīng)編程等。2.1 aspectjg

30、regor kiczales等人于1997年提出了面向方面編程(aop, aspect-oriented programming)概念2,開發(fā)出了第一個(gè)基于java的aop實(shí)現(xiàn)aspectj11。aspectj引入了連接點(diǎn)(join point)這個(gè)概念,以及切入點(diǎn)(pointcut)、通知(advice)、類型間聲明(inter-type declaration)和方面(aspect)的構(gòu)造塊。連接點(diǎn)為程序流中的一些特殊點(diǎn),包括方法調(diào)用與執(zhí)行,構(gòu)造函數(shù)調(diào)用與執(zhí)行,類或?qū)ο蟪跏蓟?,成員變量的訪問和修改,異常處理執(zhí)行,通知執(zhí)行等。方面可以在這些點(diǎn)改變系統(tǒng)的行為。切入點(diǎn)組合了連接點(diǎn),并可以提供連接

31、點(diǎn)處執(zhí)行上下文的信息。切入點(diǎn)主要用于通知,通知在切入點(diǎn)改變系統(tǒng)行為。aspectj定義了原子切入點(diǎn)(primitive pointcut),如“call(void point.setx(int)”;也定義了與(&)、或(|)、非(!)來組合切入點(diǎn)??梢杂猛ㄅ浞麃硎占喾N連接點(diǎn),如“call(void point.set*(.)”,表示調(diào)用point的以set開頭且返回值為void的函數(shù),不論這些函數(shù)的參數(shù)類型和個(gè)數(shù)。通知在切入點(diǎn)影響系統(tǒng)的行為。通知有多種類型,before通知在指定連接點(diǎn)抵達(dá)但與該連接點(diǎn)相連的程序運(yùn)行前執(zhí)行;after returning通知在指定連接點(diǎn)處的程序成功返回后執(zhí)行;

32、after throwing通知在指定連接點(diǎn)處程序拋出throwable對(duì)象后執(zhí)行;after通知在指定連接點(diǎn)程序執(zhí)行后執(zhí)行,不論成功返回還是拋出異常;around通知在指定連接點(diǎn)處執(zhí)行,只有在around通知體里顯式調(diào)用proceed,該連接點(diǎn)處的程序才能執(zhí)行。類型間聲明改變程序的結(jié)構(gòu)。在方面里可以聲明其他類型擁有的成員(成員變量、成員函數(shù)、構(gòu)造函數(shù)),也可以聲明一些類型實(shí)現(xiàn)一個(gè)新的接口或繼承一個(gè)新的類。方面將這些切入點(diǎn)、通知、類型間聲明封裝起來,形成一個(gè)關(guān)注點(diǎn),與類一樣,方面也可有成員變量和成員函數(shù)。同一個(gè)連接點(diǎn)可以被多個(gè)方面或一個(gè)方面里的多個(gè)通知影響,aspectj定義了這些方面和通知的

33、優(yōu)先關(guān)系。這些概念以及構(gòu)造塊的詳細(xì)內(nèi)容可以參考12。圖2-1是一個(gè)電信模擬的計(jì)時(shí)方面。public aspect timing public long customer.totalconnecttime = 0;public long gettotalconnecttime(customer cust) return cust.totalconnecttime;private timer connection.timer = new timer();public timer gettimer(connection conn) return conn.timer; after (connecti

34、on c): target(c) & call(void cplete() gettimer(c).start();pointcut endtiming(connection c): target(c) &call(void connection.drop();after(connection c): endtiming(c) gettimer(c).stop();c.getcaller().totalconnecttime += gettimer(c).gettime();c.getreceiver().totalconnecttime += gettimer(c).gettime();圖2

35、-1 timing方面12它給每個(gè)連接引入一個(gè)計(jì)時(shí)器,給每個(gè)用戶引入一個(gè)保存全部連接時(shí)間的變量。在連接建立完成時(shí)開始計(jì)時(shí),在連接斷開后,停止計(jì)時(shí),并計(jì)算連接時(shí)間和增加通話用戶的全部連接時(shí)間值。aspectj編譯器是一個(gè)編織器(weaver),它可以將方面織入到它所影響的其他方面或類里,以改變系統(tǒng)的結(jié)構(gòu)和行為。這樣,系統(tǒng)的關(guān)注點(diǎn)可以分別編寫,從而有效分離了關(guān)注點(diǎn),然后將這些模塊化的關(guān)注點(diǎn)通過編織器組合在一起,形成滿足需求的系統(tǒng)。2.2 aspectc+aspectc+13,14對(duì)c+進(jìn)行擴(kuò)展以支持面向方面編程,它參考aspectj所使用的方法來對(duì)另一種編程語言進(jìn)行擴(kuò)展,所以它們的模型基本相同,語

36、法上有些不同。在aspectj中“*”,表示通配符,但是在c+中“*”用來聲明指針,為避免二義性,在aspectc+中以“%”表示通配符。在aspectc+中以“:”代替aspectj中的“.”來表示作用域解析。以“”來匹配函數(shù)簽名的任意數(shù)量形參。在aspectc+中,有兩種切入點(diǎn):名字切入點(diǎn)(name pointcut)和代碼切入點(diǎn)(code pointcut)。名字切入點(diǎn)是類型、屬性、函數(shù)、變量和名字空間的名字,如“%array”表示任何以“array”結(jié)尾的class、struct或union;“void draw()”匹配有任意數(shù)量形參和返回類型為“void”的函數(shù)draw。代碼切入點(diǎn)

37、要調(diào)用aspectc+定義的函數(shù)且以名字切入點(diǎn)為參數(shù)來形成,如:call(“void draw()”)描述了一系列的函數(shù)draw調(diào)用。另外,為了重用切入點(diǎn),可以用pointcut(pointcut為關(guān)鍵字)表達(dá)式對(duì)切入點(diǎn)命名,即命名切入點(diǎn)(named pointcut),如pointcut arrays()=derived(“array”),這樣arrays能用在表示derived(“array”)切入點(diǎn)表達(dá)式可用的任何地方。在aspectc+中也有兩類連接點(diǎn),名字連接點(diǎn)用來形成名字切入點(diǎn),如程序中的類名;代碼連接點(diǎn)用來形成代碼切入點(diǎn),如程序中的函數(shù)調(diào)用和執(zhí)行。對(duì)于名字切入點(diǎn),通知可以擴(kuò)展程序

38、代碼和數(shù)據(jù)結(jié)構(gòu),即引入(與aspectj中類型間聲明一樣)。對(duì)于代碼切入點(diǎn),通知在切入點(diǎn)影響系統(tǒng)的行為。與aspectj一樣,方面以模塊化的方式收集橫切關(guān)注點(diǎn)的advice代碼和引入。圖2-2顯示了traceshape 方面來記錄shape類型的對(duì)象的構(gòu)造和析構(gòu)。aspect traceshapepublic:static int m_created,m_destroyed;pointcut shapes()=derived(shape);advice shapes(): class helperpublic:helper()traceshape:m_created+;helper()trac

39、eshape:m_destroyed+;m_counter;advice execution(% main(.) : after()printf(shape created:%d,destroyed:%d,m_created,m_destroyed);int traceshape:m_created=0;int traceshape:m_destroyed=0;圖2-2 traceshape方面2.3 組合過濾器(composition filters,cf)cf是語言獨(dú)立的模型,它以模塊化和正交化(orthogonal)的方式擴(kuò)展了面向?qū)ο竽P汀?模塊化的擴(kuò)展意味著過濾器可以附貼在對(duì)象上而不

40、改變對(duì)象的定義,這樣過濾器與實(shí)現(xiàn)獨(dú)立;正交化的擴(kuò)展即過濾器之間的語義互相獨(dú)立,這樣過濾器可以組合15。因?yàn)閷?duì)象之間的通信的機(jī)制是消息,這個(gè)模型通過過濾器來操控進(jìn)入或出去的消息來改變對(duì)象的行為,圖2-3 描述了這個(gè)模型的組成部分。圖2-3 cf模型的組件16上圖描述了一個(gè)cf模型中的對(duì)象,這個(gè)對(duì)象包括接口和實(shí)現(xiàn)兩部分。接口部分包括接口對(duì)象i聲明(被封裝了的內(nèi)部對(duì)象和被引用了的外部對(duì)象),狀態(tài)s(state, condition)聲明,類方法m聲明和過濾器f;實(shí)現(xiàn)部分包括實(shí)例變量聲明,類方法和狀態(tài)的實(shí)現(xiàn),以及初始化方法。對(duì)象可以用四元組表示17。接口對(duì)象的申明方式是為objectname:clas

41、sname;狀態(tài)s表示為: 。狀態(tài)可以看成一個(gè)用proposition表示布爾函數(shù),用id可以引用這個(gè)狀態(tài)。對(duì)象的所有方法u0包括對(duì)象內(nèi)部定義的方法m0和接口對(duì)象定義的方法(滿足遞歸規(guī)則): 過濾器定義為:handler(f)即過濾器處理器(filter-handler),它定義了當(dāng)消息到達(dá)過濾器時(shí)如何操控這個(gè)消息。a(f)被稱為接受集合(accept set function),是一個(gè)有序的集合a。a定義了狀態(tài)方法對(duì)集合,狀態(tài)s決定了消息(方法)m是否被接受。消息必須被過濾器集合檢查,檢查的算法如圖2-4:1) algorithm pass_filters(m, f)2) forall f

42、in f = f1, ., fn do3) accept := false;4) forall in a(f) = , ., do5) if (m = mj)sj then6) begin7) accept := true;8) dest := target(mj);9) break;10) end;11) endfor;12) if accept13) then handler(f).acceptmessage(m)14) else handler(f).rejectmessage(m);15) endfor;16) dispatch(m, dest);17) end pass_filter

43、s;圖2-4 檢查接受的消息算法17消息要被所有的過濾器檢查,過濾器用它的接受集合檢查消息,如果滿足接受集合里的一個(gè)元素,那么通過當(dāng)前過濾器的檢查,然后轉(zhuǎn)到下一個(gè)過濾器。如果消息不滿足當(dāng)前過濾器的接受集合所有元素,消息根據(jù)過濾器處理器的類別拒絕消息。當(dāng)通過最后的過濾器后,消息被分發(fā)。預(yù)定義的過濾器類:dispatch 過濾器:如果接受消息,消息分發(fā)到消息的當(dāng)前目標(biāo)對(duì)象;否則消息傳遞到下一個(gè)過濾器(如果沒有了過濾器,會(huì)產(chǎn)生異常)。error過濾器:如果拒絕消息,產(chǎn)生異常;否則傳遞到下一個(gè)過濾器。wait過濾器:如果接受消息,消息傳遞到下一個(gè)過濾器;否則排隊(duì)等待接受。meta過濾器:如果拒絕消息,

44、消息傳遞到下一個(gè)過濾器;否則根據(jù)這個(gè)消息生成一個(gè)對(duì)象,并把這個(gè)對(duì)象作為參數(shù)傳到新的消息(接受集合元素的第二部分)中。接受到這個(gè)新消息對(duì)象可以操控這個(gè)消息。在實(shí)時(shí)系統(tǒng)中,繼承以前經(jīng)過驗(yàn)證的模塊很重要,但是實(shí)時(shí)需求的改變往往會(huì)導(dǎo)致過多的重新設(shè)計(jì),這種情況稱為實(shí)時(shí)需求繼承反常,即子類時(shí)間需求改變導(dǎo)致在子類里出現(xiàn)過多的重新設(shè)計(jì)而不是繼承父類的已有實(shí)現(xiàn)。下面用18中的例子介紹實(shí)時(shí)需求繼承反常以及用cf模型解決的方法。類distributionnode代表一個(gè)電力分配網(wǎng)中的一個(gè)結(jié)點(diǎn)。這個(gè)節(jié)點(diǎn)有一條電力產(chǎn)生線和多條電力消費(fèi)線。結(jié)點(diǎn)控制電流從生產(chǎn)線流向消費(fèi)線。當(dāng)生產(chǎn)線斷開時(shí),所有的消費(fèi)線都要在預(yù)定義的時(shí)間內(nèi)斷

45、開。結(jié)點(diǎn)可以看成時(shí)一個(gè)電磁開關(guān),用elmagneticswitches定義,這個(gè)類里為每條線定義了連接和斷開方法。假定有一個(gè)fastdistributionnode,它是distributionnode的子類,fastdistributionnode定義消費(fèi)線斷開的截至?xí)r間比它的父類更緊迫。但是由于實(shí)時(shí)需求與應(yīng)用代碼混和在一起,子類需要重新定義消費(fèi)線的斷開方法,以使用新的時(shí)間約束,這樣父類的斷開方法無法重用,出現(xiàn)了第一種反常。用cf解決的方法是把時(shí)間約束放到過濾器中,過濾器把時(shí)間約束加到接受的消息上,如圖2-5。當(dāng)子類的時(shí)間約束改變后,新的時(shí)間約束放到子類的過濾器中,當(dāng)調(diào)用子類的方法時(shí)(繼承自

46、父類),子類過濾器給接受的消息加上新的時(shí)間約束,如圖2-6。 (1) class distributionnode interface(2) begin(3) internals(4) myswitch: elmagneticswitches;(5) methods(6) productionlinedisconnected returns nil;(7) disconnectconsumerline(integer) returns nil;(8) inputfilters(9) givetimespec: realtime = true = self.* | time.minend( tc

47、onsumer ) | ;(10) settimeforproduction: realtime = true = ductionlinedisconnected(11) | time.setend( numberoflines * time.getend ) | ;(12) invoke: dispatch = true = myswitch.*, true = inner.* ;(13) end;圖2-5 distributionnode的接口定義18過濾器類realtime的輸入過濾器用來影響與過濾器匹配消息的時(shí)間屬性。消息將接受“|”里的時(shí)間約束。消息的時(shí)間屬性用tim

48、e對(duì)象表示,time有start(消息的最早開始時(shí)間)和end(消息的截至?xí)r間)屬性。time定義了一些方法來操作這兩個(gè)屬性:如minend()給消息設(shè)置最早的截至?xí)r間(如果time point的值小于消息當(dāng)前的截至?xí)r間,則消息截至?xí)r間為,否則不變);setend()設(shè)置end屬性為參數(shù);getend:返回end屬性。givetimespec過濾器的接受集合只有一個(gè)元素,“”左邊是狀態(tài)(條件),右邊是方法的名字,是的另一種寫法。這里條件為“tue”。如果消息與distributionnode提供的方法匹配,則接受該消息,如果新的時(shí)間屬性小于消息的當(dāng)前截至?xí)r間,則過濾器為消息設(shè)置新的截至?xí)r間。如

49、果到來的消息是productionlinedisconnected,它會(huì)通過第一個(gè)過濾器,在那里設(shè)置其最早截至?xí)r間,然后會(huì)傳到第二個(gè)過濾器,在這里設(shè)置其截至?xí)r間為numberoflines * time.getend,其中numberoflines是消費(fèi)線跳數(shù),time.getend返回第一個(gè)過濾器設(shè)置的最早截至?xí)r間。 最后添加了時(shí)間約束的消息由invoke分發(fā)過濾器分發(fā)。(1) class fastdistributionnode interface(2) begin(3) internals(4) mynode: distributionnode;(5) filters(6) fastti

50、mespec: realtime = true = self.* | time.minend (tconsumernew) | (7) invoke: dispatch = true = mynode.* ;(8) end;圖2-6 fastdistributionnode的接口定義fasttimespec過濾器給fastdistributionnode的消息設(shè)置最早截至?xí)r間tconsumernew,然后消息分發(fā)到其內(nèi)部對(duì)象mynode(這是cf模型實(shí)現(xiàn)繼承的方法,稱為基于委托的繼承)。被分發(fā)的消息還要接受父類的過濾器檢查,但是由于新的截至?xí)r間小于父類過濾器里的截至?xí)r間,所以父類的giveti

51、mespec過濾器不會(huì)改變截至?xí)r間,settimeforproduction會(huì)用消費(fèi)線條數(shù)乘上新的截至?xí)r間設(shè)置productionlinedisconnected消息的截至?xí)r間。這樣滿足了新的時(shí)間約束,并且重用了父類代碼,消除了時(shí)間需求與應(yīng)用代碼混雜在一起時(shí)帶來的繼承反常。當(dāng)同樣的實(shí)時(shí)需求在一個(gè)類系的每個(gè)需要的地方都需聲明時(shí),易于出錯(cuò),并且不容易加入有同樣實(shí)時(shí)需求的方法,這樣出現(xiàn)了非多態(tài)(non-polymorphic)實(shí)時(shí)反常。由于過濾器有匹配的能力,所以可以在過濾器處為多個(gè)匹配的方法集中添加時(shí)間約束,而不用在方法里申明時(shí)間,這樣消除了非多態(tài)實(shí)時(shí)反常。如果相互獨(dú)立的實(shí)時(shí)需求通過繼承組合在一起

52、時(shí),那么它們之間會(huì)相互影響,這樣開發(fā)人員需要重新定義相互影響的需求,出現(xiàn)了正交限制反常。由于過濾器的語義也是正交的,它們的組合可以解決這個(gè)問題。過濾器可以用來表達(dá)橫切關(guān)注點(diǎn),它不但能表示單個(gè)對(duì)象的關(guān)注點(diǎn),也可以表示橫跨多個(gè)對(duì)象的組合關(guān)注點(diǎn)15。 2.4 hyperspace2.4.1 多維關(guān)注點(diǎn)分離為了控制軟件的復(fù)雜性,提高軟件的可理解性,軟件開發(fā)需要把系統(tǒng)分解為小的可管理的模塊,然后組合這些開發(fā)好的模塊得到完整的系統(tǒng)。為了方便軟件維護(hù)與演進(jìn),要求減少改變帶來的影響,要求模塊的可替換性以及提高軟件生命周期過程中各種制品間的可追蹤性。雖然在這些領(lǐng)域進(jìn)行了很好的研究與應(yīng)用,但這些問題仍然存在,這主

53、要是由于當(dāng)前軟件開發(fā)方法一次僅支持一種關(guān)注點(diǎn)的分離。如面向?qū)ο笾С謱?duì)象的分離,把數(shù)據(jù)封裝在一起,但是阻礙了特征的演進(jìn)與增加,因?yàn)檫@需要修改和增加多個(gè)類里的方法和數(shù)據(jù),需要侵入系統(tǒng)內(nèi)部。即問題原因在于“主分解專制”(tyranny of the dominant decomposition)19。為了達(dá)到軟件工程的目的,就需要同時(shí)分解多種關(guān)注點(diǎn)。多維關(guān)注點(diǎn)分離(multi-dimensional separation of concerns,mdsoc)要求支持任意多的關(guān)注點(diǎn)維數(shù),能同時(shí)沿著這些方向分解關(guān)注點(diǎn),能動(dòng)態(tài)處理新的關(guān)注點(diǎn)新的分解方向,能處理重疊交互的關(guān)注點(diǎn)20。下面以19,20中的例子

54、來說明主分解專制帶來的問題。這個(gè)例子是構(gòu)建和演進(jìn)一個(gè)簡單的軟件工程環(huán)境(software engineering environment,see)來處理程序的表達(dá)式。see支持表達(dá)式程序的創(chuàng)建與操作。包括計(jì)算表達(dá)式的值并顯示結(jié)果的計(jì)算(evaluation)工具,顯示工具和檢查語法和語義的檢查工具。系統(tǒng)的結(jié)構(gòu)如圖2-7。它把表達(dá)式表示成抽象語法樹(asts),每個(gè)ast結(jié)點(diǎn)都由一個(gè)類表示,類定義了訪問和修改方法,以及實(shí)現(xiàn)計(jì)算工具的eval()方法,實(shí)現(xiàn)顯示工具的display()方法,實(shí)現(xiàn)檢查工具的check()方法。圖2-7 see的初始設(shè)計(jì)制品19現(xiàn)在為了減少不必要的重新計(jì)算而提高性能,需

55、要對(duì)計(jì)算結(jié)果進(jìn)行緩存,這樣一個(gè)簡單的需求對(duì)設(shè)計(jì)和代碼帶來了顯著的影響:它需要在基類里增加保存緩存結(jié)果的變量以及這個(gè)變量的訪問方法,修改每個(gè)類的setter方法,修改每個(gè)類的eval()方法使得它能返回一個(gè)緩存的結(jié)果。顯然它需要侵入已有的設(shè)計(jì)和代碼中進(jìn)行修改,支持緩存的代碼與其它代碼交織在了一起,降低了了可理解性和功能的演進(jìn)。如果系統(tǒng)要增加風(fēng)格檢查(style check)功能,并且希望風(fēng)格檢查能與系統(tǒng)原來的語法語義檢查任意結(jié)合,同樣需要侵入修改,這要影響系統(tǒng)在設(shè)計(jì)和編碼的所有模塊。問題就在于主分解專制。主分解滿足一些重要的需要,但是阻礙了另一些,如數(shù)據(jù)的分解符合了應(yīng)用領(lǐng)域的概念,但是功能特征的代碼分散在多個(gè)模塊中并且與其他功能特征代碼混雜在一起19。2.4.2 hyperspacehyperspace21是一個(gè)支持多維關(guān)注點(diǎn)分離的模型。系統(tǒng)的各種關(guān)注點(diǎn)用原來的方法實(shí)現(xiàn),然后通過組合規(guī)則把它們組合在一起。軟件是由制品組成的,每種制品有它自己的描述或?qū)崿F(xiàn)方法,每種方法有它自己的語法單元(unit),如方法,類,狀態(tài)圖等等。單元可分為原子單元和組合單元,原子單元在在特定上下文中不可分割,如方法,實(shí)例變量,組合單元由原子單元組成,如類,包,圖等。關(guān)注點(diǎn)空間(concern space)組織領(lǐng)域內(nèi)的單元以分離所有重要的關(guān)注點(diǎn)。hyperspace就是一種支持多維關(guān)注點(diǎn)分離的

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(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)論