• 【java规则引擎】《Drools7.0.0.Final规则引擎教程》第4章 4.2 ruleflow-group&salience


    转载至:https://blog.csdn.net/wo541075754/article/details/75299888

    ruleflow-group

    在使用规则流的时候要用到ruleflow-group属性,该属性的值为一个字符串,作用是将规则划分为一个个的组,然后在规则流当中通过使用ruleflow-group属性的值,从而使用对应的规则。该属性会通过流程的走向确定要执行哪一条规则。在规则流中有具体的说明。 
    代码实例

    package com.rules
    
    rule "test-ruleflow-group1"
        ruleflow-group "group1"
        when
        then
            System.out.println("test-ruleflow-group1 被触发");
        end
    rule "test-ruleflow-group2"
        ruleflow-group "group1"
        when
        then
            System.out.println("test-ruleflow-group2 被触发");
        end
    View Code

    salience

    用来设置规则执行的优先级,salience属性的值是一个数字,数字越大执行优先级越高,同时它的值可以是一个负数。默认情况下,规则的salience默认值为0。如果不设置规则的salience属性,那么执行顺序是随机的。 
    示例代码:

    package com.rules
    
    rule salience1
        salience 3
        when
        then
            System.out.println("salience1 被执行");
        end
    
    rule salience2
    
        salience 5
        when
        then
            System.out.println("salience2 被执行");
        end
    View Code

    执行结果:

    salience2 被执行
    salience1 被执行
    View Code

    显然,salience2的优先级高于salience1的优先级,因此被先执行。

    Drools还支持动态saline,可以使用绑定绑定变量表达式来作为salience的值。比如:

    package com.rules
    
    import com.secbro.drools.model.Product
    
    rule salience1
        salience sal
        when
            Product(sal:discount);
        then
            System.out.println("salience1 被执行");
        end
    View Code

    这样,salience的值就是传入的FACT对象Product的discount的值了。

    
    
  • 相关阅读:
    几道简单容易被问的题
    java IO流学习总结
    Spark学习(二) -- Spark整体框架
    Spark学习(一) -- Spark安装及简介
    Python -- 数据加载、存储与文件格式
    Python库安装
    Python -- 基础
    reactive-turtle
    DP4J -- mnist
    初识DeepLearning4j
  • 原文地址:https://www.cnblogs.com/shangxiaofei/p/9438987.html
Copyright © 2020-2023  润新知