The idea remain the same. Some use-relations are important for the overall component structure and some are not. Let's have a look at some examples.
First of all, let's have a look at the following structure. Component owns Command owns Argument. But the Argument itself has a use-Relations to type. Imagine a function declaration f(int a, float b) where the argument a has a type int and b has type float. The relation of a method argument to its type is simply functional an will never appear as a relation in an UML diagram.
data:image/s3,"s3://crabby-images/ddff0/ddff019f9818611e9b40d8bb3c9c43f7bd3369d4" alt=""
The second example show a meta-model which declares that components may extend/subclass other components. This relationship is clearly structural because it's important from the component's view. Just imagine the specialization relation in a UML diagram.
data:image/s3,"s3://crabby-images/0bf2a/0bf2a3035c331d2d40a03e9115dd91de258b75a7" alt=""
The next example shows a meta-model for a component which has a collaboration relation to other components. The difference to the above design is that the collaboration relation has a role which has further information (i.e. at least a name.) For that reason the role has to be designed as an own class on the meta level called Collaborator in the subsequent example.
data:image/s3,"s3://crabby-images/aa935/aa93581d4f49ff18113ee1bc3e92ce3b3dea1a33" alt=""
Let me give a résumé: First of all we distinguish structural and functional use-relation. As a rule of thumb only structural use-relations matters for the overall component structure.
Taking a closer look at structural use-relations one notice that there are relations with and without roles. If no role is needed the design is simple as seen above. If A extends B the extends relation between A and B needs no further information.
data:image/s3,"s3://crabby-images/8fc3d/8fc3d33b88a0f1141d1e8cebfb4521be8cfbc7ec" alt=""
But if we do need to distinguish roles for a structural use-relation this role has to be modeled in a separate class providing at least a name. In the example below component A uses B1 as xAxis and B2 as yAxis. Note that xAxis and yAxis are instances of Collaborator.
data:image/s3,"s3://crabby-images/362b8/362b8f4c8fe63d9e0df0612388f9bf18f9a186dd" alt=""
It's quite interesting that the class Collaborator of the meta-model is visualized as a role in the instance-model. Since the decision if a structural use-relation needs a role or not is taken by the designer, we have to distinguish 3 different modes for use-relations:
- functional use-relation
- structural use-relation without a role
- structural use-relation with a role
To conclude this blog let's think if this concept might work for a generic diagram editor which can visualize meta-model and model at the same time. For this reason let's have a look at the following simplified UML meta-model (which can be seen as meta-meta-model for our example).
data:image/s3,"s3://crabby-images/db3f5/db3f5863ba102cf51edaf14c14816c0d512107b1" alt=""
- The type-relation from Argument to Class is a functional use-relation
- The extends relation from class to class is a structural use-relation without a role
- The type-relation from Member to Class is a structural use-relation with a role (Member play the role)
This comment has been removed by a blog administrator.
ReplyDelete