3

我想在 UML 枚举类型中表示一些键值对。例如,假设我们有一些元素及其符号:

ROAD => 'R'
CAR => 'C'
NOTHING => ' '

在 Java 中,它类似于以下内容:

public enum AsciiCodes { 
    ROAD  ('R'),
    CAR ('C'),
    NOTHING (' ');

    private final char code;

    private AsciiCodes(char code) {
        this.code = code;
    }
}

我如何在 UML 中表示它?

到目前为止我所拥有的:

在此处输入图像描述

4

2 回答 2

4

在 UML ROAD 中,CARNOTHINGEnumerationLiteral,在类图中,它们显示在显示其名称的隔间文字中,仅此而已。

作为Datatype的枚举可能具有属性,但是您的 Java 中的属性代码不能像您那样被属性支持,因为它不涉及枚举,而是涉及EnumerationLiteral

当然EnumerationLiteral不是枚举的属性,也不是枚举的实例,而是InstanceSpecification

因此,在您通过构造型扩展枚举以将代码添加为StructuralFeature之前,没有任何标准允许为每个枚举文字建模代码及其值,在这种情况下,代码的值将通过Slot指定

正式/2017-12-05看到:

  • § 10.5.3 枚举第 175 页
  • § 10.5.4 EnumerationLiteral 第 175 和 176 页
  • § 9.9.9 实例规范第 140 页

[编辑]

UML 中的替代表示形式受到阅读Christophe答案的启发。

另一种方法是完全忘记 UML EnumerationLiteral,并通过一个专用实例本身对每个 Java 枚举文字进行建模,该实例本身可通过静态只读属性获得。

AsciiCodes仍然可以是 UML 枚举。

在此处输入图像描述

请注意,在您的 Java 定义及以上代码的值从外部不可用,然后最终无用,直到添加操作以按照Christophe的回答中建议的方式返回它。

顺便说一句,这就是我仍然使用Java 代码生成器专门管理的构造型 enum_patternJava的BoUML插件的 API 中实现枚举的方式。我在 2005 年开始分发 BoUML,当时 Java 中还没有枚举。

于 2020-11-25T13:34:17.147 回答
3

我想为Bruno的出色而鼓舞人心的答案添加一些细微差别。

枚举可以在 UML 中具有属性和操作吗?

UML 枚举是一个分类器。因此,它可以完美地拥有自己的属性和操作,即使大多数时候它只定义枚举字面量(另请参见这个 SO answer)。这非常接近 Java 枚举。

然而, Java 枚举提供了一些语法糖,允许将一个或多个常量值关联到每个枚举字面量。该语言允许您定义一个私有构造函数,该构造函数使用这些常量值来初始化枚举对象。这意味着您可以很好地在 UML 中表示您的枚举,如下所示:

在此处输入图像描述

与枚举字面量相关的常量值是什么?

UML 中没有任何内容允许您对与枚举字面量关联的常量值进行建模。 但没有什么需要:这只是一个实现细节。如果您想要模型中的常量,您可以在注释中记录它们(我不会那样做,因为它只会使图表混乱,其中包含无助于理解设计的实现细节)。

您有两种选择来阐明初始化:

  1. 您定义一个与您的代码具有相同签名的显式构造函数,其优点是它接近您的代码。但是 UML 不是代码的替代品,不是吗?. 不便之处在于它对 UML 读者来说是误导性的不清楚:它给人的印象是这些初始化参数是免费的;
  2. 您依赖没有参数的构造函数。优点是它反映了设计现实:构造函数参数不是免费的,因为 Java 使用直接从枚举文字推导出的常量值调用构造函数。

我建议使用 2,因为它传达了真正的设计意图。如果没有语法糖,您可能会编写一个很长的case语句来根据 enum litteral 使用正确的值初始化属性。

其他 Java 枚举功能如何?

UML 枚举不提供超出您明确定义的任何内容。
但是 Java 枚举都是专门java.lang.Enum的,它们提供name()诸如values().

如果您想传达这种特定于语言的特性的可用性,您可以定义自己的原型 «Java enum»,专门用于标准 UML 枚举元模型元素。

于 2020-11-26T00:09:52.330 回答