lock-on-active
当在规则上使用ruleflow-group属性或agenda-group属性的时候,将lock-on-active 属性的值设置为true,可避免因某些Fact对象被修改而使已经执行过的规则再次被激活执行。可以看出该属性与no-loop属性有相似之处,no-loop属性是为了避免Fact被修改或调用了insert、retract、update之类的方法而导致规则再次激活执行,这里的lock-on-active 属性起同样的作用,lock-on-active是no-loop的增强版属性,它主要作用在使用ruleflow-group属性或agenda-group属性的时候。lock-on-active属性默认值为false。与no-loop不同的是lock-on-active可以避免其他规则修改FACT对象导致规则的重新执行。
因FACT对象修改导致其他规则被重复执行示例:
package com.rules import com.secbro.drools.model.Product; rule rule1 no-loop true when obj : Product(discount > 0); then obj.setDiscount(obj.getDiscount() + 1); System.out.println("新折扣为:" + obj.getDiscount()); update(obj); end rule rule2 when productObj : Product(discount > 1); then System.out.println("其他规则被触发了" + productObj.getDiscount()); end
执行之后打印结果为:
新折扣为:2 其他规则被触发了2 第一次执行命中了2条规则!• 1 • 2 • 3
其他规则(rule2)因FACT对象的改变而被出发了。
通过lock-on-active属性来避免被其他规则更新导致自身规则被重复执行示例:
package com.rules import com.secbro.drools.model.Product; rule rule1 no-loop true when obj : Product(discount > 0); then obj.setDiscount(obj.getDiscount() + 1); System.out.println("新折扣为:" + obj.getDiscount()); update(obj); end rule rule2 lock-on-active true when productObj : Product(discount > 1); then System.out.println("其他规则被触发了" + productObj.getDiscount()); end
很明显在rule2的属性部分新增了lock-on-active true。执行结果为:
新折扣为:2 第一次执行命中了1条规则!• 1 • 2
标注了lock-on-active true的规则不再被触发。