使用GMF开发可视化界面编辑器(五)——模型的约束校验

本文介绍了如何使用GMF结合EMF的验证框架和OCL表达式来实现模型约束校验,包括流程设计的约束,如唯一开始和结束节点、节点间不能直接连接、节点名称唯一及任务分配器的指定。通过映射模型配置约束,并展示静态校验的过程和结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    大千世界,约束无处不在,拿人来讲,活在社会当中,享受权利和义务的同时,也必须要遵守相应的法律约束。而这里我们所说的模型约束校验,就相当于为流程设计人员事先声明的法律,一旦不遵守规定,流程就会提示出错。

    GMF所提供的约束校验功能其实是使用了EMF的Validate子框架,并且在约束声明上使用了OCL表达式来完成。有关OCL表达式的语法不做过多讲解,可参考Object Constraint Language一书,这里主要介绍几个常用的函数:

针对实体类的:

    oclIsTypeOf (t : Classifier) : Boolean——判断该实体类是否是Classifier类型;

    oclIsKindOf (t : Classifier) : Boolean——判断该实体类是否是Classifier类型或其子类;

    oclAsType (t : Classifier)——将实体类强制转换成Classifier类型。

针对集合的(注意:集合方法通过->引用):

    collection->select( boolean-expression )——对集合进行筛选,返回满足boolean-expression的实体集合;

    collection->forAll( boolean-expression )——对集合中的所有实体进行boolean-expression校验,当所有实体都校验通过时返回true,否则返回false;

    collection->exists( boolean-expression )——集合中是否存在满足boolean-expression约束的实体。

 

由于只是为了做实例演示,所以我们只简单声明了以下几个约束信息:<

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值