軟件建模與UML第八章對象約束語言_第1頁
軟件建模與UML第八章對象約束語言_第2頁
軟件建模與UML第八章對象約束語言_第3頁
軟件建模與UML第八章對象約束語言_第4頁
軟件建模與UML第八章對象約束語言_第5頁
已閱讀5頁,還剩106頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

第八章對象約束語言第一節(jié)OCL概述第二節(jié)OCL語法第三節(jié)標(biāo)準(zhǔn)OCL類型第四節(jié)OCL表達(dá)式第五節(jié)OCL在UML建模中的應(yīng)用

第一節(jié)OCL概述UML的圖形如類圖、用例圖等,通常不可能詳細(xì)地表達(dá)系統(tǒng)的各個細(xì)節(jié),為了表達(dá)這些細(xì)節(jié)問題,需要為建模對象添加一些約束。這些約束可以使用自然語言來表達(dá),但是自然語言的二義性增加了約束表達(dá)的復(fù)雜性和不可確定性。為解決約束表達(dá)的問題,OCL應(yīng)運(yùn)而生了。

第一節(jié)OCL概述對象約束語言(ObjectConstrainLanguage,簡稱OCL)是UML的子標(biāo)準(zhǔn),是一種能用于構(gòu)造軟件模型的建模語言。第一節(jié)OCL概述OCL的特性:OCL是一種精確的、無二義性的形式化語言,易于掌握和使用。OCL既具有良好的數(shù)學(xué)背景,又沒有使用晦澀的數(shù)學(xué)符號。OCL的基礎(chǔ)是集合論和三值Kleene邏輯,并且它有一個形式化的數(shù)學(xué)語義,因此它可以明確地、無歧異地表示模型元素。

第一節(jié)OCL概述OCL是強(qiáng)類型的語言,任何表達(dá)式的值都屬于一個類型。這個類型可以是預(yù)定義的標(biāo)準(zhǔn)類型(如String或Integer型),也可以是UML圖中的元素(如具體的對象),還可以是這些元素構(gòu)成的集合(如對象的Set,Bag和sequencetypes等)。作為類型語言,OCL表達(dá)式的校驗(yàn)是在建模期間而不是執(zhí)行期間進(jìn)行的,因此,模型中的錯誤能在早期就被發(fā)現(xiàn)并修改。第一節(jié)OCL概述OCL是聲明式的語言,其表達(dá)式的計算將返回一個值,不會改變系統(tǒng)的狀態(tài),沒有副作用,從而使得UML中的表達(dá)式被提升到了純建模的領(lǐng)域。而不必考慮實(shí)現(xiàn)時的細(xì)節(jié)和具體語言。OCL是一種制定約束和查詢的文本語言,除了可用于編寫導(dǎo)航表達(dá)式、布爾表達(dá)式和其他查詢語句外,還可用于構(gòu)建約束、監(jiān)護(hù)條件、動作、前置和后置條件、斷言和其他UML表達(dá)式。第一節(jié)OCL概述OCL是一種規(guī)范說明性語言,所有與實(shí)現(xiàn)有關(guān)的問題都不能用OCL來表達(dá)。OCL不是一種程序設(shè)計語言,不能用OCL編寫程序邏輯和控制流程。第一節(jié)OCL概述OCL具體語言可以用于許多不同的目的:作為一種查詢語言。在類模型中,指定與類和類型有關(guān)的不變式。為原型和屬性指定一種類型不變式。為屬性指定派生規(guī)則。描述關(guān)于操作和方法的前置條件和后置條件。描述遷移。為消息和動作指定一個目標(biāo)和一個目標(biāo)集合。第一節(jié)OCL概述

在UML模型中指定任意表達(dá)式,如與行為(Behavior)、參數(shù)(Parameters)、變更觸發(fā)器(ChangeTriggers)和時間觸發(fā)器(TimeTriggers)、及生命線(LifeLines)相關(guān)聯(lián)的那些表達(dá)式。第二節(jié)OCL語法OCL2.0在兩個層次上定義對象約束語言,一個是抽象語法(或元模型),另一個是具體語法。后者真正用于在UML模型中指定約束和進(jìn)行查詢。元模型定義OCL概念和應(yīng)用該概念的規(guī)則(或抽象語法),這與UML元模型對圖的概念和用于UML圖的規(guī)則進(jìn)行定義的方式相同。具體語法實(shí)現(xiàn)抽象語法。

第二節(jié)OCL語法1)抽象語法抽象語法指的是OCL語言定義的概念層。在UML中,抽象語法表示為解釋“類是什么”或“操作是什么”等的元模型(M2層),而不是創(chuàng)建一個具體的類或操作,UMLM2層一般將類描述為“具有相同的特征、約束和語義說明的一組對象”,并將類解釋為可以與任何數(shù)目的特性(或?qū)傩裕?、操作、關(guān)系甚至嵌套類相關(guān)聯(lián)。第二節(jié)OCL語法2)具體語法與面向規(guī)則的抽象語法相反,具體語法應(yīng)用抽象語法的規(guī)則來創(chuàng)建可以在運(yùn)行時段計算的表達(dá)式。OCL表達(dá)式與類元相關(guān)聯(lián),應(yīng)用于該類元自身或某個屬性、操作或參數(shù)。不論哪種情況,約束都是根據(jù)其位移(replacement)、上下文類元(contextualclassifier)和OCL表達(dá)式的自身實(shí)例(selfinstances)來定義的。第二節(jié)OCL語法“位移”是UML模型中使用的OCL表達(dá)式所處的位置,即作為依附某個類元的不變式、依附于某個操作的前置條件或依附于某個參數(shù)的默認(rèn)值?!吧舷挛念愒倍x在其中計算表達(dá)式的名字空間。例如,前置條件的“上下文類元”是在其中定義該前置條件的操作所歸屬的那個類。也就是說,該類中的所有模型元素(如屬性、關(guān)聯(lián)和操作)都可以在OCL表達(dá)式中被引用。第二節(jié)OCL語法

“自身實(shí)例”是對計算該表達(dá)式的對象的引用。它總是“上下文類元”的一個實(shí)例。也就是說,OCL表達(dá)式對該“上下文類元”的每個實(shí)例計算結(jié)果可能不同。因此,OCL可以用于計算測試數(shù)據(jù)。第三節(jié)標(biāo)準(zhǔn)OCL類型OCL是一種強(qiáng)類型語言,每一表達(dá)式的值都屬于某一類型。圖8-1顯示了OCL中預(yù)定義的類型以及從UML模型派生的類型的層次結(jié)構(gòu)?!癈lassfier”是一個基本類型,包含UML基礎(chǔ)結(jié)構(gòu)的分類器的所有子類型。VoidType是一個與所有類型均具有一致性的類型。VoidType類型只有一個實(shí)例,稱為OclViod。TupleType類型(非正式的記錄類型或結(jié)構(gòu)體類型)將不同類型組合到一起形成一個新的類型。第三節(jié)標(biāo)準(zhǔn)OCL類型圖8-1OCL類型核心元模型的抽象語法層次結(jié)構(gòu)第三節(jié)標(biāo)準(zhǔn)OCL類型

OCL標(biāo)準(zhǔn)庫定義了多種類型,如圖8-2所示。注意:OCL標(biāo)準(zhǔn)庫中定義的類型都是其抽象語法類的實(shí)例。標(biāo)準(zhǔn)庫處在建模層即M1層,抽象語法處于元模型層即M2層。第三節(jié)標(biāo)準(zhǔn)OCL類型圖8-2OCL標(biāo)準(zhǔn)庫中的類型定義第三節(jié)標(biāo)準(zhǔn)OCL類型1、OclAny和OclViod類型2、OclMessage類型3、基本類型4、集合類型5、類型一致性6、類型轉(zhuǎn)換

1、OclAny和OclViod類型1)OclAny在OCL標(biāo)準(zhǔn)庫中,OclAny類型是所有UML模型和基本類型的超類型,UML模型所有的類都繼承由OclAny定義的特性。為了避免模型特性的名字與從OclAny繼承的特性名字發(fā)生沖突,OclAny特性名字都以“Ocl”開頭。1、OclAny和OclViod類型OclAny類型上的操作表1、OclAny和OclViod類型2)OclVoid類型OclVoid與其它所有類型都具有一致性。OclVoid僅有一個稱為OclUndefined的實(shí)例。contextOclVoidinv:OclVoid.allinstances()->size()=1除oclIsUndefined()操作之外,任何應(yīng)用在OclUndefined類型上的屬性調(diào)用結(jié)果都是OclUndefined類型。2、OclMessage類型OclMessage事實(shí)上是一個帶有參數(shù)“T”的模板類型,一個具體的OclMessage類型通過傳遞一個操作或信號參數(shù)代替“T”而被創(chuàng)建。

下表是有關(guān)OclMessage的操作。3、基本類型定義在OCL標(biāo)準(zhǔn)庫中的基本類型有:Integer,Real,String和Boolean。除此之外,OCL還在基本類型上定義了一些操作,如下表所示。4、集合類型OCL中還定義了一些較為高級的標(biāo)準(zhǔn)OCL類型,稱為集合類型。集合類型是成組的對象或元素,可以作表達(dá)式計算過程的結(jié)果。在OCL標(biāo)準(zhǔn)庫中,集合類型包括Collection抽象類型,還有Set、Bag、OrderedSet和Sequence。:1)Collection類型Collection類型是其他集合類型的超類型。4、集合類型定義在Collection類型上的操作

操作說明size():Integer返回指定Collection中的元素個數(shù)count(object:T):Integer返回參數(shù)對象在指定Collection中出現(xiàn)的次數(shù)includes(object:T):Boolean當(dāng)對象是指定Collection的一個元素時,返回真excludes(object:T):Boolean當(dāng)對象不被包含在指定Collection中時,返回真includesAll(c2:Collection(T)):Boolean當(dāng)指定Collection包含參數(shù)c2中所有元素時,返回真excludesAll(c2:Collection(T)):Boolean當(dāng)指定Collection不包含參數(shù)c2中任何元素時,返回真isEmpty():Boolean當(dāng)指定Collection不包含任何元素時,返回真notEmpty():Boolean當(dāng)指定Collection至少有一個元素時,返回真sum():T返回指定Collection中所有元素的和product(c2:Collection(T2)):Set(Tuple(first:T,second:T2))返回指定Collection與c2Collection的迪卡爾積Iterate()訪問集合中的元素并查詢或計算表達(dá)式4、集合類型2)Set類型Set類型是不包括重復(fù)元素的對象組,Set類型中的元素是無序的。4、集合類型

定義在Set類型上的操作

操作說明union(s:Set(T)):Set(T)返回指定Set與參數(shù)s的聯(lián)合體,結(jié)果是Set類型union(bag:Bag(T)):Bag(T)返回指定Set與參數(shù)bag的聯(lián)合體,結(jié)果是Bag類型=(s:Set(T)):Boolean當(dāng)指定Set與s包含相同的元素時,返回真intersection(s:Set(T)):Set(T)返回指定Set與參數(shù)s的交集intersection(bag:Bag(T)):Set(T)返回指定Set與參數(shù)bag的交集–(s:Set(T)):Set(T)返回指定Set與參數(shù)s的差集including(object:T):Set(T)返回包含在指定Set中的所有元素以及參數(shù)對象的Setexcluding(object:T):Set(T)返回指定Set中的除參數(shù)對象以外的所有元素的SetsymmetricDifference(s:Set(T)):Set(T)返回包含在指定Set和參數(shù)Set中,但不同時包含在這兩個Set中的元素組成的Setcount(object:T):Integer返回參數(shù)對象在指定Set中出現(xiàn)的次數(shù)asSet():Set(T)返回指定Set本身asOrderedSet():OrderedSet(T)返回指定Set中移除所有重復(fù)元素后,所有元素以隨機(jī)順序組成的OrderedSetasSequence():Sequence(T)返回指定Set中所有元素的以隨機(jī)順序組成的SequenceasBag():Bag(T)返回包含Set中所有元素的Bag4、集合類型3)OrderedSet類型OrderedSet類型是不包括重復(fù)元素,并且有序的對象組。

4、集合類型定義在OrderedSet類型上的操作

操作說明append(object:T):OrderedSet(T)返回指定OrderedSet所有元素,并在后面加上參數(shù)對象object組成的OrderedSetprepend(object:T):OrderedSet(T)返回參數(shù)對象object并在后面加上指定OrderedSet所有元素組成的OrderedSetinsertAt(index:Integer,object:T):rderedSet(T)返回在指定位置插入?yún)?shù)對象object后所組成的OrderedSetsubOrderedSet(lower:Integer,upper:Integer):OrderedSet(T)返回指定OrderedSet中從lower到upper位置元素組成的子OrderedSetat(i:Integer):T返回指定OrderedSet中第i個位置的元素indexOf(obj:T):Integer返回參數(shù)對象obj在指定OrderedSet中出現(xiàn)有位置索引first():T返回指定OrderedSet的第一個元素last():T返回指定OrderedSet的最后一個元素4、集合類型4)Bag類型Bag類型也是對象組,Bag類型與Set類型的不同之處在于Bag類型中可以包含重復(fù)元素。

4、集合類型定義在Bag類型上的操作

操作說明=(bag:Bag(T)):Boolean當(dāng)指定Bag與參數(shù)bag包含相同的元素時,返回真<>(bag:Bag(T)):Boolean當(dāng)指定Bag與參數(shù)bag不包含相同的元素時,返回真union(bag:Bag(T)):Bag(T)返回指定Bag與參數(shù)bag的聯(lián)合體,結(jié)果是Bag類型union(set:Set(T)):Bag(T)返回指定Bag與參數(shù)set的聯(lián)合體,結(jié)果是Bag類型intersection(bag:Bag(T)):Bag(T)返回指定Bag與參數(shù)bag的交集intersection(set:Set(T)):Set(T)返回指定Bag與參數(shù)set的交集including(object:T):Bag(T)返回包含在指定Bag中的所有元素以及參數(shù)對象的Bagexcluding(object:T):Bag(T)返回指定Bag中除參數(shù)對象以外的所有元素的Bagcount(object:T):Integer返回參數(shù)對象在指定Bag中出現(xiàn)的次數(shù)asBag():Bag(T)返回指定Bag本身asSequence():Sequence(T)返回以隨機(jī)順序包含Bag中所有元素的SequenceasSet():Set(T)返回Bag中移除所有重復(fù)元素后所有元素組成的SetasOrderedSet():OrderedSet(T)返回Bag中移除所有重復(fù)元素后所有元素以隨機(jī)順序組成的OrderedSet4、集合類型5)Sequence類型Sequence類型和Bag類型類似,也可以包含重復(fù)元素,不過Sequence類型中的元素是有序的。

4、集合類型

定義在Sequence類型上的操作

操作說明count(object:T):Integer返回參數(shù)對象在指定Sequence中出現(xiàn)的次數(shù)=(s:Sequence(T)):Boolean當(dāng)指定Sequence與參數(shù)Sequence中包含相同的元素、相同的元素出現(xiàn)次數(shù)以及相同的元素順序時,返回真<>(s:Sequence(T)):Boolean當(dāng)指定Sequence與參數(shù)Sequence中不包含相同的元素、相同的元素出現(xiàn)次數(shù)以及相同的元素順序時,返回真union(s:Sequence(T)):Sequence(T)返回指定Sequence與參數(shù)Sequence的聯(lián)合序列,即聯(lián)合后的Sequenceappend(object:T):Sequence(T)返回包含在指定Sequence中的所有元素,并在后面加上參數(shù)對象的Sequenceprepend(object:T):Sequence(T)返回由參數(shù)對象加上指定Sequence中的所有元素組成的SequenceinsertAt(index:Integer,object:T):Sequence(T)返回將參數(shù)對象object插入到給定index位置后,所有元素組成的SequencesubSequence(lower:Integer,upper:Integer):Sequence(T)返回指定Sequence中從lower到upper位置的元組成的子Sequenceat(i:Integer):T返回指定Sequence中第i個位置的元素indexOf(obj:T):Integer返回參數(shù)對象obj在指定Sequence中的索引號4、集合類型

定義在Sequence類型上的操作

操作說明first():T返回Sequence中的第一個元素last():T返回Sequence中的最后一個元素including(object:T):Sequence(T)返回包含在指定Sequence中的所有元素,并加上參數(shù)對象作為最后一個元素的Sequenceexcluding(object:T):Sequence(T)返回指定Sequence中除參數(shù)對象以外的所有元素的SequenceasBag():Bag(T)返回包含所有重復(fù)元素的在內(nèi)的所有Sequence元素組成的BagasSequence():Sequence(T)返回指定Sequence本身asSet():Set(T)返回指定Sequence中移除所有重復(fù)元素后所有元素組成的SetasOrderedSet():OrderedSet(T)返回指定Sequence中移除所有重復(fù)元素后所有元素組成的OrderedSet5、類型一致性O(shè)CL的類型層次結(jié)構(gòu)決定了不同類型之間的一致性。例如不能讓Integer類型的變量跟Boolean或String的變量進(jìn)行比較。只有滿足類型一致性的表達(dá)式才是有效的表達(dá)式。如果出現(xiàn)類型不匹配時,OCL就會包含類型一致性錯誤。如果無論任何時候type1的一個實(shí)例均能用type2的一個實(shí)例來代替,那么稱類型Type1與類型Type2一致。5、類型一致性類型一致性規(guī)則:

任何類型都與它的超(上級)類型一致類型一致性具有可傳遞性類型一致性具體自反性5、類型一致性

OCL中類型一致性表

類型一致于條件Set(T1)Collection(T2)ifT1conformstoT2Sequence(T1)Collection(T2)ifT1conformstoT2Bag(T1)Collection(T2)ifT1conformstoT2IntegerRealOclVoidTheothertypeinOCL6、類型轉(zhuǎn)換某些情況下,我們希望能夠使用一個對象的屬性,這個屬性的類型是當(dāng)前已知類型的子類型。由于其類型在當(dāng)前類型范圍內(nèi)未定義,這將導(dǎo)致類型一致性錯誤。當(dāng)確定兩個類型一致之后,對象可以使用oclAsType(OclType)操作進(jìn)行類型轉(zhuǎn)換。例如,可以用如下表達(dá)式將類型為Type1的對象轉(zhuǎn)換為Type2類型的對象。object.oclAsType(Type2)--evaluatestoobjectwithtypeType2第四節(jié)OCL表達(dá)式OCL表達(dá)式核心元模型的抽象語法層次結(jié)構(gòu)參見圖8-3

,充分體現(xiàn)了OCL與UML元模型之間的關(guān)系。定義了OCL中可以使用的各種表達(dá)式類型。第四節(jié)OCL表達(dá)式圖8-3OCL表達(dá)式核心元模型的抽象語法層次結(jié)構(gòu)第四節(jié)OCL表達(dá)式圖8-4ModelPropertyCallExp類型細(xì)節(jié)圖第四節(jié)OCL表達(dá)式ModelPropertyCallExtp表達(dá)式涉及模型中的屬性、操作或關(guān)聯(lián)端。ModelPropertyCallExtp元類有三個子類型:AttributeCallExp、OperationCallExp和AssociationEndCallExp,表示source的特征。因?yàn)槠渌恍ο蟪3R{(diào)用這些屬性,一個ModelPropertyCallExtp有一個OclExpression作為Source。例如,在表達(dá)式Employee.getsalary()中,Employee是OclExpression,它是getsalary()部分的source,而getsalary()部分是ModelpropertyCallExp的一個實(shí)例。第四節(jié)OCL表達(dá)式

作用于collection上的循環(huán)表達(dá)式是LoopExp元類的實(shí)例。例如,collection→forA11(elem|elem

staitisfiesacondition)

其中的forAll操作是循環(huán)表達(dá)式LooPExepressions的一個實(shí)例。每個循環(huán)表達(dá)式都有一個source,該source是一個collection或一個作為collection來處理的實(shí)例,并可以用OCL表達(dá)式來描述。循環(huán)體部分表明collection的哪些元素需要被考慮。第四節(jié)OCL表達(dá)式

IfExp用于描述依據(jù)判斷條件二選一的抽象語法。

OclMessageExp多用于描述通信(操作調(diào)用或信號發(fā)送)發(fā)生。

VariableExp是指變量相關(guān)表達(dá)式,包括self、result所指的變量以及由Let表達(dá)式所定義的變量。

LiteralExp是一個無參數(shù)的表達(dá)式,產(chǎn)生一個值,這個值通常是一個符號表達(dá)式,比如,一個Integer類型的數(shù)值“1”,或者是一個文本串“’thisisaLiteralExp”。第四節(jié)OCL表達(dá)式1、OCL表達(dá)式的特點(diǎn)2、OCL的表達(dá)式示例與語法3、中綴運(yùn)算符4、操作符優(yōu)先級5、關(guān)鍵字6、注釋

1、OCL表達(dá)式的特點(diǎn)OCL表達(dá)式用于對一個OCL類型求值,它具有如下特點(diǎn):1)OCL表達(dá)式可以附加在模型元素上,模型元素的所有實(shí)例都應(yīng)該滿足表達(dá)式的條件。2)OCL表達(dá)式可以附加在操作上,附加在操作上的表達(dá)式要指定執(zhí)行一個操作前應(yīng)該滿足的條件(前置條件)或一個操作完成后必須滿足的條件(后置條件)。1、OCL表達(dá)式的特點(diǎn)3)OCL表達(dá)式可以指定附加在模型元素上的監(jiān)護(hù)條件。4)OCL表達(dá)式的計算原則是從左到右。計算子表達(dá)式得到一個具體的值或一個具體類型的對象。5)OCL表達(dá)式既可以使用基本類型又可以使用集合類型。2、OCL的表達(dá)式示例與語法字符和變量是最簡單的表達(dá)式,self表達(dá)式引用類元的一個實(shí)例。23——字符表達(dá)式V一一變量表達(dá)式self——self表達(dá)式.P.name()——操作調(diào)用.substring(2)一一嵌套操作調(diào)用Set{1,2}->size——集合上的操作調(diào)用3+2——中綴表達(dá)式self.age——屬性訪問2、OCL的表達(dá)式示例與語法通過操作調(diào)用及“if-then-else”結(jié)構(gòu)可建立起復(fù)雜的表達(dá)式。ifx.mod(2)=0then‘even’e1se‘odd’Endif——if表達(dá)式2、OCL的表達(dá)式示例與語法OCL表達(dá)式的語法用擴(kuò)展的巴斯科范式(EBNF)定義,在EBNF中,“|”表示選擇,“?”表示可選項(xiàng),“*”表示一次或多次。OCL基本表達(dá)式的語法用EBNF定義如下:PrimaryExpression:=Literalcollection|Literal|PathnametimeExpression?featureCallParameters?|”(“expression”)”|ifExpression2、OCL的表達(dá)式示例與語法Literal:=<String>|<number>|”#”<name>timeExpression:=”@”<name>featrueCallParameters:=”(“declarator”)?(actualParameterList)?”)”ifExpression:=”if”expression“then”expression“else”expression“endif”2、OCL的表達(dá)式示例與語法從上面的定義可以看出,OCL的基本表達(dá)式可以是一個Literalcollection,Literalcollection代表Literal的集合類型。OCL的基本表達(dá)式可以是一個Literal,Literal可以是一個字符串、數(shù)字或者是“#”后面跟一個模型元素或操作的名字。2、OCL的表達(dá)式示例與語法OCL的基本表達(dá)式可以是一個包含可選項(xiàng)的路徑名,后面的可選項(xiàng)中包括時間表達(dá)式(timeExpression)、限定符(Qualifer)、或特征調(diào)用參數(shù)(featrueCallParameters)。OCL的基本表達(dá)式還可以是一個條件表達(dá)式“ifExpression”。3、中綴運(yùn)算符OCL的中綴運(yùn)算符有:+、-、*、/、<、>、<>、<=、>=、And、Or、Xor等。4、操作符優(yōu)先級操作符的優(yōu)先級:按照從高到低來進(jìn)行;使用小括號時,從最內(nèi)到最外進(jìn)行計算。

5、關(guān)鍵字與程序設(shè)計語言一樣,OCL也定義了一些關(guān)鍵字。and、attr、context、def、else、endif、endpackage、if、implies、in、inv、let、not、oper、or、package、post、pre、then、xor。以上OCL關(guān)鍵字是保留字,它們不能作為一個包(package)、類型(type)或者屬性(property)等的名稱在表達(dá)式中出現(xiàn)。6、注釋在OCL中,使用現(xiàn)兩個連續(xù)短劃線表示注釋符,從這兩個短劃線開始,一直到換行符為上的內(nèi)容都是注釋。例如:--thisisacomment第五節(jié)OCL在UML建模中的應(yīng)用為了便于本節(jié)的描述,我們使用圖8-5所示的類圖作為本節(jié)的例子。第五節(jié)OCL在UML建模中的應(yīng)用圖8-5UML類圖示例第五節(jié)OCL在UML建模中的應(yīng)用1、OCL與UML元模型2、用OCL表達(dá)對象性質(zhì)約束3、OCL的支持工具

1、OCL與UML元模型1)上下文(context)上下文是約束所依附的模型元素。UML模型中OCL上下文是用以保留字“context”開頭的表達(dá)式來描述的。例如,contextPerson::income(d:Date):Integerpost:result=5000此例中,后置條件約束的上下文為Person類的income(d:Date)操作。1、OCL與UML元模型2)包的上下文當(dāng)用作分類器的包與外界環(huán)境關(guān)系清晰時,上述的上下文聲明已經(jīng)足夠精確。當(dāng)情況復(fù)雜時,為了說明不變量、前置條件、后置約束條件屬于那個包,這些約束可以包含在“package”和“endpackage”聲明之間。

1、OCL與UML元模型包上下聲明語法如下:package

Package::SubPackagecontextXinv:...someinvariant...context

X::operationName(..)pre:...someprecondition...endpackage

1、OCL與UML元模型3)self每一個OCL表達(dá)式都存在于一個具體描述類型實(shí)例的上下文中。OCL表達(dá)式中,用保留字“self”來表示上下文實(shí)例。例如,context

Person::getCurrentSpouse():Personpre:self.isMarried=truebody:self.mariages->select(m|m.ended=false).spouse

此例中,對操作約束的上下文是Company,self就指的是Company的一個實(shí)例。子表達(dá)式self.isMarried的值是對象Person(用self標(biāo)識)屬性isMarried的值,其類型為Boolean。1、OCL與UML元模型4)操作體表達(dá)式一個OCL表達(dá)式可以用來說明一個查詢操作的結(jié)果。語法如下:contextTypename::operationName(param1:Type1,...):ReturnTypebody:--someexpression1、OCL與UML元模型操作體表達(dá)式的類型必須與操作返回的類型一致。與前置、后置條件一樣,表達(dá)式中也可使用參數(shù)。在操作聲明之后,前置、后置條件表達(dá)式,操作體表達(dá)式可以混合使用。例如:contextPerson::getCurrentSpouse():Personpre:self.isMarried=truebody:self.mariages->select(m|m.ended=false).spouse1、OCL與UML元模型5)初始值和派生值OCL表達(dá)式可以表示屬性或關(guān)聯(lián)端的初始值和派生值。語法如下:context

Typename::attributeName:Typeinit:--someexpressionrepresentingtheinitialvaluecontext

Typename::assocRoleName:Typederive:--someexpressionrepresentingthederivationrule

1、OCL與UML元模型此處,初始值和派生值表達(dá)式的類型必須跟屬性的結(jié)果類型一致。當(dāng)上下文是關(guān)聯(lián)端時,如果關(guān)聯(lián)端的多重性為0..1,表達(dá)式類型必須與關(guān)聯(lián)端分類器一致。如果關(guān)聯(lián)端的多重性為1..*,表達(dá)式的類型與Set或OrderedSet類型一致。初始值和派生值可以在同一個上下文中混合使用。

1、OCL與UML元模型例如:contextPerson::income:Integerinit:parents.income->sum()*1%--pocketallowancederive:if

underAgethen

parents.income->sum()*1%--pocketallowanceelse

job.salary--incomefromregularjobendif1、OCL與UML元模型前置條件中的初值的表示方法前置條件中對象屬性的值是上次操作后的返回值。為了引用操作前的值,OCL使用“@pre”后綴來達(dá)到獲取操作前值的目的。例如,ContextPerson::birthdayHappens()Post:age=age@pre+1屬性age的值是一個Person對象執(zhí)行此操作的值,屬性age@pre的值為此操作前的值,即前置條件初始值。1、OCL與UML元模型6)前置條件中的初值的表示方法前置條件中對象屬性的值是上次操作后的返回值。為了引用操作前的值,OCL使用“@pre”后綴來達(dá)到獲取操作前值的目的。例如,ContextPerson::birthdayHappens()Post:age=age@pre+1屬性age的值是一個Person對象執(zhí)行此操作的值,屬性age@pre的值為此操作前的值,即前置條件初始值。1、OCL與UML元模型7)Let表達(dá)式OCL可以使用Let表達(dá)式定義變量,一旦該變量被定義,就可以整個約束中使用這個變量。例如:contextPersoninv:letincome:Integer=self.job.salary->sum()inifisUnemployed

thenincome<100elseincome>=100endif1、OCL與UML元模型8)definition約束為了能夠讓變量或操作在多個OCL表達(dá)式中重用,OCL使用definition約束定義在計算上下文類元的任何時候都可使用的變量的方式。definition約束必須依附于類,并且只能包含變量或者操作,作用域只能在同一個上下文。其語法與Let表達(dá)式類似,但每個屬性和操作都以“def”為前綴。1、OCL與UML元模型例如:contextPersondef:income:Integer=self.job.salary->sum()def:nickname:String=’LittleRedRooster’def:hasTitle(t:String):Boolean=self.job->exists(title=t)2、用OCL表達(dá)對象性質(zhì)約束所謂對象性質(zhì),就是一個對象的屬性、操作等與對象有關(guān)的特性,在建模中具體是指定義的模型元素的特性。以下是用OCL表達(dá)對模型元素的性質(zhì)的約束幾種常見情況。

1)屬性約束建模不變量:常用于附加在模型元素上,在屬性的生命期內(nèi)一直保持為真的規(guī)則。例如ContextPersoninv:Self.allInstances->forAll(P1,P2|P1<>P2impliesP1.PId<>P2.PId)2、用OCL表達(dá)對象性質(zhì)約束多數(shù)情況下,上下文十分明確,關(guān)鍵字“self”可以省略。可以定義一個不同的名稱代替“self”,例如:Contextc:Company

inv:c.numberofEmployees>50可以把約束名稱寫在保留字“inv”的后面,并允許用這個名稱引用它表的約束。下面這個例子中的約束名稱是enoughEmployees。Contextc:Company

inv

enoughEmployees:c.numberofEmployees>502、用OCL表達(dá)對象性質(zhì)約束變量約束:Let表達(dá)式附加在模型元素的屬性上,它通常用于定義約束中的一個變量。比如一個學(xué)生類的屬性綜合評分“totalscore”是由成績得分“score”和附加分“addings”組成的。ContextStudentinv:Let

totalscore:Integer=self.score->sumIfnoAddingsthen

totalscore<=80Else

totalscore>=20endif2、用OCL表達(dá)對象性質(zhì)約束2)對操作約束建模OCL表達(dá)式附加操作上可以規(guī)定一個前置條件或后置條件。前置條件指的是操作開始執(zhí)行前必須為真的條件,后置條件指的是操作成功執(zhí)行后必須為真的條件。前置條件用保留字“Pre”標(biāo)識,后置條件用保留字“post”標(biāo)識。contextTypename::operationName(param1:Type1,...):ReturnTypepre:param1>...post:result=...2、用OCL表達(dá)對象性質(zhì)約束參數(shù)名也可以在OCL表達(dá)式中使用。例如,對一個公司雇用員工的操作可以附加前置條件和后置條件:Contextcompany::hirEmployee(p:person)Pre:notemployee->include(p)--前置條件Post:employee->include(p)andstockprice()=stockprice@pre+5--后置條件2、用OCL表達(dá)對象性質(zhì)約束類似于不變量,前置條件和后置條件也可以有自己的條件名,分別寫在保留字“pre”和“post”的后面,并可用條件名(前置或后置條件名)來引用它所代表的條件約束。例如:contextTypename::operationName(param1:Type1,...):ReturnTypepreparameterOk:param1>...postresultOk:result=...此OCL表達(dá)式中,使用前的置條件名稱為parameterOk,后置條件名稱為resultOk。UML元模型中,這些名稱是從模型元素(metElement)繼承而來的元類約束的屬性名稱的值。3、OCL的支持工具OCL的支持工具一般具有如下主要功能。語法分析類型檢查邏輯一致性檢查代碼生成動態(tài)驗(yàn)證不變式動態(tài)驗(yàn)證前/后置條件測試自動化與CASE工具的集成3、OCL的支持工具下面是幾種典型的OCL工具。1)ModelRun

ModelRun由Boldsoft公司所開發(fā),用于驗(yàn)證模型。它是一個對OCL表達(dá)式進(jìn)行處理的商業(yè)化工具。該工具支持的建模工具有RationalRoes2、BoldforDelphi等。

3、OCL的支持工具M(jìn)odelRun有如下特點(diǎn):對模型中的OCL表達(dá)式作語法檢查和類型檢查。約束可用來驗(yàn)證模型,在該工具中,可對創(chuàng)建的對象執(zhí)行模型的約束。OLC表達(dá)式編輯器允許手工引入約束并可使用編輯器中提供的選項(xiàng),這些選項(xiàng)主要是為構(gòu)建正確的OCL表達(dá)式提供向?qū)ё饔?。像其它的OCL工具一樣,ModelRun不會直接修改UML模型。UML模型的引入是通過XML文件來進(jìn)行。OCL表達(dá)式分析器是ModelRun的一部分,因此不能使用它作為模型獨(dú)立的工具。比如,該分析器不能用來對單獨(dú)的OCL表達(dá)式作語法分析。3、OCL的支持工具2)OCLCheckerOCLChekcer是Jos

Warrmer開發(fā)的一種直觀易用的OCL表達(dá)式分析器,其最終版支持OCLI.4規(guī)范,OCLChecker由單個文件(ocl.jar)組成。OCLChecker僅僅能被用作為獨(dú)立于模型的工具,因?yàn)樗鼪]有提供與UML模型連接的方式。相對其它的OCL分析器而言,OCLChekcer的主要缺點(diǎn)是其功能僅限于對OCL語言作語法分析,它既沒有考慮類型檢查也沒有考慮約束的一致性檢查。3、OCL的支持工具3)DresdenOCL編譯器:一種開源的模塊化工具,它是Dresdne技術(shù)大學(xué)FrankFinger開發(fā)的,其目的是由OCL表達(dá)式生成Java代碼,并且在運(yùn)行時計算OCL表達(dá)式。3、OCL的支持工具DresdenOCL編譯器包含四個功能模塊:解析器、語義分析、規(guī)范化、代碼生成。解析器是由SableCC解析器生成器根據(jù)OCL文法產(chǎn)生的。解析器把輸入的OCL表達(dá)式轉(zhuǎn)化為抽象語法樹,抽象語法樹為該工具中的其它功能模塊構(gòu)成了通用數(shù)據(jù)表示。語義分析作簡單的一致性檢查和類型檢查。規(guī)范化通過簡化解析器產(chǎn)生的抽象語法樹使得代碼生成階段變得更容易,也即減少了代碼生成的復(fù)雜性。代碼生成模塊的作用是把OCL表達(dá)式轉(zhuǎn)化為相應(yīng)的可執(zhí)行代碼。3、OCL的支持工具4)USE:由Bremen大學(xué)MarkRichters開發(fā)的一種OCL工具。其功能如下:對UML和OCL描述進(jìn)行語法檢查。通過對對象、屬性、聯(lián)系的操縱來產(chǎn)生系統(tǒng)狀態(tài)。表示出系統(tǒng)的狀態(tài)圖中的對象。3、OCL的支持工具監(jiān)視模型的本質(zhì)特性和類圖中的不變式。執(zhí)行操作并監(jiān)視其前置條件和后置條件。表示出順序圖中的操作的調(diào)用順序。用OCL表達(dá)式查詢系統(tǒng)狀態(tài)。3、OCL的支持工具該工具主要的組件是一個模擬器和一個OCL解釋器。模擬器用于模擬UML模型,解釋器則主要是用于驗(yàn)證模型中的OCL約束。模型是系統(tǒng)的描述,系統(tǒng)狀態(tài)則是運(yùn)行著的系統(tǒng)快照。USE工具用于操縱系統(tǒng)快照,并且因此根據(jù)系統(tǒng)的要求驗(yàn)證模型。在USE規(guī)范中,OCL約束描述了系統(tǒng)的要求,所以操縱系統(tǒng)快照期間驗(yàn)證了這些約束。

UML元模型

UML是通過一個元模型來正式定義的,元模型就是UML中結(jié)構(gòu)的模型。元模型本身也是用UML來表達(dá)的。這是一個元循環(huán)解釋的例子,即一種用自己來定義自己的語言。但也不完全是循環(huán)的,用于定義元模型的只是UML的一個小子集。從理論上說,可以從一個更基本的定義自行引導(dǎo)出這種定義的支點(diǎn)。但在實(shí)踐中,進(jìn)行這種探討是沒有必要的。因此,本書將其納入附錄以供讀者參閱。

UML元模型

模型是系統(tǒng)的完整抽象,圖則是模型或模型子集的圖形表示。按照面向?qū)ο蟮膯栴}解決方案以及建立系統(tǒng)模型的要求,UML語言從4個抽象層次對UML語言的概念、模型元素和結(jié)構(gòu)進(jìn)行了全面定義,并規(guī)定了相應(yīng)的表示法和圖形符號。

UML體系結(jié)構(gòu)

UML具有一個四層體系結(jié)構(gòu),每個層次是根據(jù)該層中元素的一般性程度來劃分的。從一般到具體依次為元元模型層、元模型層、模型層和用戶對象層。圖F-1給出了UML的四層體系結(jié)構(gòu)。

UML體系結(jié)構(gòu)

圖F-1UML的四層體系結(jié)構(gòu)

UML體系結(jié)構(gòu)

1)元元模型(meta-metamodel)層的主要任務(wù)是定義用于規(guī)定元模型的語言,因此形成了元模型建模層次結(jié)構(gòu)的基礎(chǔ)。元元模型通常比它所描述的元模型具有更高的抽象級別、更加簡潔。一個元元模型可以定義多個元模型,而每個元模型也可以與多個元元模型相關(guān)聯(lián)。在元元模型上的元元對象的例子有:元類、元屬性和元操作。

UML體系結(jié)構(gòu)

2)元模型(metamodel)是元元模型的實(shí)例,該層的主要任務(wù)是定義用于規(guī)定模型的語言

溫馨提示

  • 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. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論