用C# XMI技术进行UML模型捕获
2008-04-09 04:03:12来源:互联网 阅读 ()
在本文中,我将展示如何通过使用XMI和C#来剖析一个UML发布图。首先,我展示一个该方法的简单的发布图,所在环境为一个虚构的汽车出租公司并使用C#来捕获一些数据。这种数据可以被容易地加到一个数据库(它已经是ADO调用的相当容易的一部分)上去或者作为更大些的一个基于资产的管理系统的一部分。在每一个示例中,我将逐渐增加原始图和能够获取的信息的复杂性。
一、 示例1-查找方法的名字
我要做的第一件事情是捕获来自于汽车出租公司的所有方法的名字。共有五个方法,它们是以UML发布图形描述的(见图1)。在上一篇文章中,我展示了如何用一个XML文档来描述一个发布图。为此,首先要创建该图,然后把它输出到一个XMI文件(企业架构)或解压(MagicDraw)。(在这篇文章中,我再次使用了SparxSystems.com提供的企业架构。)
图1.五个方法:图中结点描述了汽车出租公司的方法。每一个结点为一个方法名字。
我将首先开发一简单main程序-它提示用户输入描述一个有效的XMI文档的XML文档的名字。一旦输入文件名字,它就被传递到一个分析XMI文档的对象并打印输出方法名字。
using System;
using System.Text;
namespace XMI_1{
public class ConsoleUtils{
public static string ReadString(string msg) {
Console.Write(msg); return System.Console.ReadLine();
}
public static void WriteString(string msg)
{ System.Console.WriteLine(msg); }
public static void Main(string[] args) {
string name = ReadString("Please enter the XMI filename : ");
NodeParse np = new NodeParse(name);
System.Console.ReadLine();
}
}
}
下一步是分析XMI文档。为此,我必须创建一个XMLTextReader的实例并循环操作直到没有结点为止。XMLNodeType.Element检查每一个XML元素并且在元素是一个结点的情况下把它打印输出到控制台。该元素名字资格为"UML:Node",然而通过使用_readXMI.LocalName只有元素名字的"Node"被读取。详细代码参见列表1。
二、 示例2-增加模板
第二个示例重构了第一个示例来捕获方法的名字和"pc server"模板-这是一个用来决定每个结点是一个方法的UML方法。图3显示增加了模板后的方法的发布图。
第一步是修改前面的代码以识别新的模板来操纵AddNode()方法。
图3.增加了模板之后:每个模板描述了结点的类型-不管它是一个PC服务器,PC客户端或者是另外一些描述该结点的目标。
private void AddNode(XmlTextReader p_readXMI)
{
string nodeID;
string nodeName;
string stereotypeName;
nodeID = p_readXMI.GetAttribute("name");
nodeName = p_readXMI.GetAttribute("xmi.id");
Console.Write(nodeID);
Console.Write(" -> ");
Console.WriteLine(nodeName);
while (p_readXMI.Read() && (p_readXMI.NodeType == XmlNodeType.Element ||
p_readXMI.NodeType== XmlNodeType.Whitespace))
{
switch (p_readXMI.LocalName)
{
case "ModelElement.stereotype":
while (p_readXMI.Read() && (p_readXMI.NodeType == XmlNodeType.Element ||
p_readXMI.NodeType == XmlNodeType.Whitespace))
{
if (p_readXMI.LocalName == "Stereotype")
{
stereotypeName = p_readXMI.GetAttribute("name");
Console.WriteLine("Stereotype = " stereotypeName);
}
}
break;
}
}
}
特别要注意的是一个idiom(对某个语言特有的一个低级别的模式)-我用来查找在另外一些元素内部的XML元素。我在p_readXMI.Read循环中增加了代码来检查元素或者空格(在XML文档中,这是些空格字符)。只有每个元素结点在XML文档中适当的层次上处理时,这个idiom才工作。
用这种方式对元素进行封装,结果不很理想。例如,在下面的UML中使用idiom代码将产生所不希望的结果:
<UML:Node name="Leasing">
<UML:TagName name="Test">
</UML:Node name="SmallLeasing">
</UML:TagName>
</UML:Node>
图4.示例2的输出结果:在示例1中的结点名字/id之后,列出每个模板。
第一个元素被作为一个结点处理,第二个元素被忽略并在初始循环中退出,而第三个元素被作为在同一级上的第一个正常结点处理。为了修正这个问题,你可以使用XMLNodetype.Endelement来检查元素的结束标签。在本文中,这不是个问题而保存额外的代码要求检查结尾元素。
XMI中的模板被封装在结点元素中。该示例中的代码检查名字为"ModelElement.Stereotype"的元素并且使用刚才讨论的相同的idiom来处理一个"模板"类型的封装元素,然后把它打印输出到屏幕上(见图4)。(列表3列出了示例2的完全的源码。)
从资产管理的角度来看,捕获方法的名字和它们的模板并没有多大用处。当然,另一方面,如果你的图包含了描述正在使用的硬件信息也可能是非常有用的:例如,基于UML发布图把你所有的硬件保存到一个数据库将能够使你跟踪方法、客户及其如何进行彼此联系的。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:软件的架构与设计模式之什么是架构
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash