2

我正在使用 Sparx EA(当前版本)逆向工程一个简单的小测试解决方案到类图(C#,如果重要的话)。只有两个班。测试 1 和测试 2。Test1 有一个属性;

public List<Test2> test2list { get; set; }

基于该属性,我希望 EA 推断这两个类是相关的并相应地更新图表,但它没有.. 我只得到两个类并且必须手动链接它们..

有什么方法可以让 EA 识别这些关系吗?

4

1 回答 1

4

首先,我认为问题评论中的讨论突出了潜在的问题:对于 UML 中的哪些关系对应于实现语言 X 中的哪些结构没有达成共识。

换句话说,最常见的实现语言没有标准化的 UML 配置文件。(Java 有一个非常古老的版本,但它已经过时了。)我认为这是 UML 的一大缺点,在任何特定工具中都不是问题。

回答这个问题:不,在这种情况下,EA 不会推断依赖关系或用法。但这里的问题更深层次:EA 没有正确解析模板类型。

扩展您的示例,请考虑以下四种情况:

public List<Test2> test2ListProp { get; set; }
public List<Test2> test2ListAttr;
public Test2 test2SingleProp { get; set; }
public Test2 test2SingleAttr;

EA 识别属性,它表示为操作,而不是属性。它不会为这些创建任何连接器。另一方面,非属性在模型中由属性和定向关联表示。以这种方式使用的属性和定向关联在 UML 中在语义上是等价的,但对于操作则不成立。

如果您现在进入模型并重命名 Test2,您将看到 EA 正确更新了属性和属性中的非列表类型的名称,但其他类型保留了它们的List<Test2>类型。所以这就是它崩溃的地方;该List<Test2>类型只是一个字符串,而不是正确的模型引用。

您还应该注意,定向关联test2ListAttr的多重性为 0..*。这是因为 EA 已正确推断该属性实际上是一个列表。可以在工具 - 选项 - C# - 附加集合类中控制此推断。

如果您现在List<#TYPE#>;从该选项中删除,然后在您的模型中创建一个模板类List并重新导入(在这种情况下,首先清除模型可能是个好主意),EA 将更改其test2ListAttr. 它不会创建一个指向 0..* 的关联Test2,而是创建一个绑定到您的类的模板List,指定Test2为实际参数。

这是一个正确的模型引用,如果您更改Test2绑定的名称,将会更新(您可能需要重新加载图表)——换句话说,这是一个正确的表示,如果您要从此模型生成代码,这将是正确的。事实上,以这种方式设置选项并预先创建 List 类,对于上述四种情况中的三种情况,行为是正确的。

但是,这并不能解决类型为模板类的属性的问题。因为 EA 将它们表示为操作,所以它不能为它们绘制有向关联,因此,它也不会为它们绘制模板绑定。如果我是你,我应该将此报告为错误。

在相关说明中,您可以让 EA 为操作返回和参数类型创建依赖项(但不能用于模板类型使用)。这是在工具 - 选项 - 源代码工程中设置的。

于 2012-04-15T11:28:18.467 回答