SimpleBindings与ScriptEngine.createBindings()之间的区别(Graal和Nashhorn)

请注意,我同时使用了Nashhorn和Graal,因此下面使用的ScriptEngine可能是GraalJSScriptEngine或nashhorn引擎的实例。

当我使用GraalJSScriptEngine引擎致电createBindings时:

Bindings bindings = scriptEngine.createBindings();

它返回一个GraalJSBindings对象,该对象具有一个close函数,该函数关闭与绑定关联的上下文:

@Override
public void close() {
    if (context != null) {
        context.close();
    }
}

在我的应用程序中,每次使用后,我必须确保通过Graaljsbindings.close()关闭此上下文,这是为了防止内存泄漏导致上下文没有被GC处理。例如:

// Create bindings
Bindings bindings = scriptEngine.createBindings();

// Do stuff
...

// Close bindings if they implement AutoClosable
// I also use the Nashhorn engine,so its possible that bindings
// may not be an instance of AutoCloseable/Graaljsbindings
if (bindings instanceof AutoCloseable) {
    try {
        ((AutoCloseable) bindings ).close();
    } catch (final RuntimeException re) {
        throw re;
    } catch (final Exception ex) {
        LOGGER.error("Unable to close script bindings and associated context",ex);
    }
}

我注意到,还有一种创建绑定的方法,不是通过引擎,而是通过显式实例化SimpleBindings对象。我想知道下面的区别是什么,即我可以简单地将scriptEngine.createBindings()替换为new SimpleBindings(),而不必像上面一样关闭绑定吗?还是使用scriptEngine.createBindings()有一些优势?

Bindings bindings = graalJSScriptEngine.createBindings();

vs

Bindings bindings = new SimpleBindings();
handanlove521 回答:SimpleBindings与ScriptEngine.createBindings()之间的区别(Graal和Nashhorn)

内部,section.compare { width: calc(100% - 40px); max-width: 800px; display: block; margin: auto; background-color: var(--gray0); overflow: auto; border-radius: 4px; box-shadow: 0px 0px 10px 0px var(--gray2); } section.compare left { float: left; padding: 10px; background-color: red; } section.compare right { float: right; padding: 10px; background-color: green; } section.compare right,section.compare left { width: calc(50% - 20px); text-align: center; } 被包装在SimpleBindings对象中。如此有效,其行为应该是相同的。

尽管GraalJSBindings的性能可能会更好,特别是如果您重复GraalJSBindings编写相同绑定的代码。并且eval允许在评估绑定时(从另一个线程)操纵绑定。

最好, 基督徒

本文链接:https://www.f2er.com/1286691.html

大家都在问