Java mvel@includeNamed使用CompiledTemplate抛出NPE

Java mvel@includeNamed使用CompiledTemplate抛出NPE,java,mvel,Java,Mvel,我第一次使用mvel。只要运行TemplateRuntime.eval,使用就可以了 但如果我尝试使用CompiledTemplate,它会抛出一个NPE。我做错什么了吗?还是这是一只虫子?我使用的是MVEL2.1.4.Final public class App { public static void main(String[] args) { TemplateRegistry registry = new SimpleTemplateRegistry();

我第一次使用mvel。只要运行TemplateRuntime.eval,使用就可以了

但如果我尝试使用CompiledTemplate,它会抛出一个NPE。我做错什么了吗?还是这是一只虫子?我使用的是MVEL2.1.4.Final

public class App {
    public static void main(String[] args) {


        TemplateRegistry registry = new SimpleTemplateRegistry();
        registry.addNamedTemplate("world", TemplateCompiler.compileTemplate("world!!!"));

        System.out.println(TemplateRuntime.eval("Eval Hello: @includeNamed{'world'}", null, registry));

        CompiledTemplate ct = TemplateCompiler.compileTemplate("Compile Hello: @includeNamed{'world'}");
        System.out.println(TemplateRuntime.execute(ct, null, registry));
    }
}
和stacktrace(注意:Eval打印精细):

Eval你好:世界!!!
线程“main”java.lang.NullPointerException中出现异常
位于org.mvel2.integration.impl.StackResetResolverFactory。(StackResetResolverFactory.java:15)
位于org.mvel2.compiler.CompiledExpression.getDirectValue(CompiledExpression.java:123)
位于org.mvel2.compiler.CompiledExpression.getValue(CompiledExpression.java:119)
位于org.mvel2.compiler.CompiledExpression.getValue(CompiledExpression.java:113)
位于org.mvel2.MVEL.executeExpression(MVEL.java:930)
在org.mvel2.templates.res.CompiledNamedIncludeNode.eval(CompiledNamedIncludeNode.java:56)
位于org.mvel2.templates.res.TextNode.eval(TextNode.java:42)
位于org.mvel2.templates.res.TextNode.eval(TextNode.java:42)
位于org.mvel2.templates.TemplateRuntime.execute(TemplateRuntime.java:285)
位于org.mvel2.templates.TemplateRuntime.execute(TemplateRuntime.java:247)
位于org.mvel2.templates.TemplateRuntime.execute(TemplateRuntime.java:255)
位于org.mvel2.templates.TemplateRuntime.execute(TemplateRuntime.java:187)
位于mveltest.App.main(App.java:23)
在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)处
位于sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)中
位于java.lang.reflect.Method.invoke(Method.java:597)
位于com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)

嗯,这看起来像个bug。我注意到在调用VariableResolveFactory.someMethod时,NPE发生在StackResetResolveFactory的构造函数中

因此,作为一种解决方法,我使用了execute方法,该方法采用variablesolverfactory

Map<String, Object> dummyVariableMap = new HashMap<String, Object>();
VariableResolverFactory dummyResolverFactory = new SimpleVariableResolverFactory(dummyVariableMap);
System.out.println(TemplateRuntime.execute(ct, null, dummyResolverFactory, registry));
Map dummyVariableMap=newhashmap();
VariableResolveFactory DummyResolveFactory=新的SimpleVariableResolveFactory(dummyVariableMap);
System.out.println(TemplateRuntime.execute(ct,null,dummyrolverfactory,registry));
奇怪的是,我认为使用命名模板执行CompiledTemplate将是一个非常常见的用例

Map<String, Object> dummyVariableMap = new HashMap<String, Object>();
VariableResolverFactory dummyResolverFactory = new SimpleVariableResolverFactory(dummyVariableMap);
System.out.println(TemplateRuntime.execute(ct, null, dummyResolverFactory, registry));