如何解决OptaPlanner:Drools 空安全解引用运算符在 OptaPlanner DRL 规则中不起作用吗?
根据空安全解引用操作符!.
的{{3}},形式的表达式
Type( $data : property!.data )
在内部展开/表示为:
Type( property != null,$data : property.data )
但是,这在 OptaPlanner 的上下文中似乎不起作用。
对于规则
Type( $data : property!.data )
package some.classes;
import static location.RulesAHASH1.*;
import org.optaplanner.core.api.score.buildin.bendablelong.BendableLongscoreHolder;
import org.drools.modelcompiler.dsl.pattern.D;
// other imports
@org.drools.compiler.kie.builder.MaterializedLambda()
public enum LambdaExtractorAHASH2 implements org.drools.model.functions.Function1<Type,java.lang.Long> {
INSTANCE;
public static final String EXPRESSION_HASH = "SOME_HASH";
@Override()
public java.lang.Long apply(Type _this) {
return _this.getproperty() != null && _this.getproperty().getData();
}
}
鉴于 data
不是 boolean
并且 apply
的返回类型为 Long
,这会引发异常。
消息:
java.lang.IllegalStateException: There are errors in a score DRL:
Error Messages:
Message [id=1,level=ERROR,path=blah/blah/blah/LambdaExtractorHASH.java,line=24,column=54
text=bad operand types for binary operator '&&'
first type: boolean
second type: java.lang.Long]
...
// generated code etc.
那么,在使用 Drools 和 OptaPlanner 时,我们不应该使用这种表示法吗?是否有其他语言限制?
更新:
拉取 optaplanner 存储库,切换到 8.8.x,并修改了 VehicleRoutingConstriants DRL 规则以使用空安全解引用运算符:
rule "distancetoPrevIoUsstandstill"
when
$customer : Customer($prevVehicle : prevIoUsstandstill!.vehicle,prevIoUsstandstill != null,$distanceFromPrevIoUsstandstill : distanceFromPrevIoUsstandstill)
then
System.out.println($prevVehicle);
scoreHolder.addSoftConstraintMatch(kcontext,- $distanceFromPrevIoUsstandstill);
end
这按预期运行。
解决方法
更新到 8.8.x 为我解决了这个问题
解决方法:
用内部表示应该是什么替换空取消引用运算符表达式,所以,而不是这样写:
rule "name"
when
MyClass($subField : field!.subField)
// more matching
then
// do some stuff
end
这样写:
rule "name"
when
MyClass(field != null,$subField : field.subField)
// more matching
then
// do some stuff
end
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。