具有属性的 UML 建模枚举

UML modelling enumeration with attributes

我想创建一个带有 Java 枚举 (enum) 的 UML 图,它具有一个或多个属性,但我不知道如何去做。

例如,枚举可以这样声明:

public enum Enumeration_type {

   LITERAL_A("attr1_value", attr2_value, attr3_value),
   LITERAL_B("attr1_value", attr2_value, attr3_value);

   final String attr1;
   final type_1 attr2 = initial_value_1;
   final type_2 attr3;

   Enumeration_type(String attr1, type_1 attr2, type_2 attr3) {
      this.attr1_value = attr1;
      this.attr2_value = attr2;
      this.attr3_value = attr3;
   }
}

没有属性,很简单:

+--------------------+
|   <<enumeration>   |
|  Enumeration_type  |
+--------------------+
|  LITERAL_A         |
|  LITERAL_B         |
+--------------------+

但是如何使用属性优雅地对其建模呢?应该是这样吗?

+-----------------------------------------------------+
|   <<enumeration>>                                   |
|  Enumeration_type                                   |
+-----------------------------------------------------+
|  attr1: String                                      |
|  attr2: type_1 = initial_value_1                    |
|  attr2: type_2                                      |
+-----------------------------------------------------+
|  LITERAL_A("attr1_value", attr2_value, attr3_value) |
|  LITERAL_B("attr1_value", attr2_value, attr3_value) |
+-----------------------------------------------------+

我只找到了这个示例 here,但它使用字符串 class 属性作为枚举名称。我认为,这应该与未指定枚举名称数据类型的 public enum 用法不同。

+-----------------------------------------+
|   <<enumeration>>                       |
|      CarType                            |
+-----------------------------------------+
|  +sedan : String = SEDAN                |
|  +liftback : String = LIFTBACK          |
|  +stationWagon : String = STATION_WAGON |
+-----------------------------------------+

我认为您无法在 UML 中为每个枚举文字的属性值建模。
EA 使用以下符号表示具有属性的枚举:

您可以在每个文字的注释中的某处记录属性值,或者您可以使用 excel 文件或类似的文件来管理该数据。
通常您只需要在设计时提供初始值,因为它们可能会在 运行 时发生变化。因此,如果您不相信这些值是正确的,那么将这些值保留在您的模型中就没有多大用处。

您可以使用官方文档http://www.omg.org/spec/UML/2.5来正式描述您的类。在 11.4.4 部分你会发现一些像这样的例子: