|
第4回
本節ではオペレーションのマッピングについて検討します。 ■■6.1 オペレーションの種類■■ UMLのオペレーションと、対応するJavaのモデル要素の関係は図9になります。UMLのオペレーションは、Javaのインスタンスメソッド、クラスメソッド、コンストラクタのいずれかにマッピングされるということです。
Javaのインスタンスメソッドとクラスメソッドの違いは、スコープにあります。つまり、インスタンススコープを持つメソッドがインスタンスメソッドであり、クラススコープを持つメソッドがクラスメソッドとなります。スコープという概念はUMLのオペレーションにもまったく同じものがあるので、そのままJavaのインスタンスメソッドおよびクラスメソッドに対応させることができます。 Javaのコンストラクタは、UMLではオペレーションとして表現することになります。ただし、ステレオタイプcreateを設定した特殊なオペレーションという扱いになります。 ■■6.2 部品のマッピング■■ UMLオペレーションの部品とJavaメソッドおよびJavaコンストラクタの部品との対応関係は図10となります。
●6.2.1 共通の部品 オペレーション名/メソッド名、返却値型/復帰型、可視性、パラメタ、例外はUMLの部品とJavaの部品がそのまま対応します。また、UMLのプロパティabstractとJavaの修飾子abstractも同じ意味です。いずれも抽象メソッドを表します。UMLのプロパティleafにはJavaの修飾子finalが対応します。 いずれもサブクラスでオーバーライドされないメソッドを表します。ステレオタイプcreateは、Javaのコンストラクタに相当します。 ●6.2.2 要検討の部品 オペレーションの並行性を表現するために、UMLではプロパティconcurrencyを用意しており、以下の3つの値で表現します。
それに対して、Javaではメソッドの修飾子としてsynchronizedを用意しています。synchronizedを指定されたメソッドは、UMLの concurrencyプロパティのguardedと同様に、複数のクライアントからの要求はガードされ同時に1つの要求のみが実行されるようになります。つまり、UMLのconcurrencyプロパティのguardedをJavaメソッドの修飾子synchronizedにマップすることは可能です。 synchronizedが指定されていないJavaメソッドはUMLのsequentialまたはconcurrentにマップされることになりますが、どちらにマップされるかは実装次第であり、機械的なマッピングを行うことはできません。 ●6.2.3 Javaのみの部品 Javaのみの部品として、以下の2つの修飾子が挙げられます。
いずれもUMLに相当する機能がないので、ステレオタイプかプロパティで表現することになります。 ●6.2.4 UMLのみの部品 UMLのみに定義されているオペレーションの機能を表現するステレオタイプとしてdestroyがあります。Javaにはステレオタイプに相当する機能はなく、また手動での実装も困難なのであえて利用することはないでしょう。UMLのみに定義されている機能を表現するプロパティは以下の2つです。
queryは、オペレーションの呼び出しに伴う副作用がないことを表現します。rootは、親クラスのオペレーションをオーバーライドしないメソッドであることを表現します。いずれも、直接Javaにマッピングできる機能はありません。参考情報として利用するのがよいでしょう。
|
[an error occurred while processing this directive] |
||||||||||||||||||||||||||||||||||||||||


