还是从一个例子里看看EMF的使用方法和作用吧。假设我们的应用是一个网上商店,在系 统里有这些对象:商店Shop、类别Category、商品Product,其中类别可以包含子类别。现在 我们用EMF从头到尾生成一个可以管理类别和商品的应用程序。如果你的Eclipse里还没有安 装 EMF,在eclipse.org/emf下载适合你Eclipse版本的EMF SDK,建议你下载全部包含的那种 。安装后,在新建对话框里会增加EMF的类别,如图1所示:
图1 新建向导里的EMF类别
其中“EMF Model”是从已有的模型文件创建genmodel模型,这个模型是专门用来生成代 码的;如果你手里已经有一个模型(比如一个.mdl文件或是一个.xsd文件等等),可以选择 新建“EMF Project”,这样在向导的后面部分里会要求提供已有的模型文件;因为我们打算 自己从头开始建立这样的模型,所以选择“Empty EMF Project”,和建立普通插件一样,要 提供一个插件名称,我们为这个商店项目起名为com.my.shop,然后按Finish即完成向导。目 前这个新建立的项目里还没有包含任何代码,只是在META-INF/MANIFEST.MF文件里定义了对 EMF相关插件的依赖。
下面开始定义ecore模型,我比较喜欢图形化的方式,因为看起来很直观,所以我使用 Omondo公司的EclipseUML插件来画类图,这个插件的免费版本在 它们网站下载,注意下载适 合你的Eclipse的版本。当然rose也不错而且更加稳定,但它不是免费的,而且只能在 Windows里使用。和Rose不同,EclipseUML对EMF有特别的支持,安装这个插件后,我就们可 以在项目里新建一个“EMF Class Diagram”,这样会同时创建一个.ecd文件和一个.ecore文 件,EclipseUML编辑的类图信息会保存在这两个文件里,前者主要是图形方面的内容,而后 者是真正的模型信息,注意这两个文件中的任何一个都不要搞丢了,最好能经常备份一下。
在EclipseUML里编辑类图很简单,需要注意的是,两个对象之间如果有关联,要仔细考虑 关联是否为“包含”关系(一般在UML中以黑色菱形表示),如果一个类没有包含在任何其它 类里,则这个类的实例不会被保存到文件。例如图2中Category包含在Shop中,Product包含 在 Category中。这样,所有的对象都直接或间接的被Shop对象包含。换句话说,如果以Shop 作为“根”,所有的对象都可以被保存到文件里。
EMF对java基本类型和一些常用类做了包装,例如int->EInt,java.lang.Integer- >EInteger以及java.util.List->EList等等,所以在定义类的属性时要使用这些EMF的 类型,当然也有办法使用自定义类型(以后会用到)。我们例子里的模型相当简单,一共只 有三种业务对象(为了更加直观,我们增加了一个NamedElement接口),现在网上商店类图 的第一个版本如图2所示。
图2 网上商店类图(版本1.0)