作为人源Java库用户的新手,我计划使用renjin ScriptEngine并行执行多线程上的计算。显然,在每个线程上初始化一个renjin ScriptEngine实例是很好的,然后初始化的renjin实例可以由其所属线程使用。
然而,由于一个renjin实例的初始化过程需要很长时间,我突然想到了一个问题:多个线程能否共享一个enjin ScriptEngine实例并并行调用它?
发布于 2016-10-17 12:53:09
不能使用共享RenjinSession同时计算多个R表达式。从技术上讲,如果您验证所调用的R函数中没有一个影响会话级别的状态,则可以这样做,其中包括:
但是所有这些东西在基和统计包中的R函数中是很常见的。
如果希望减少初始化新RenjinSessions的开销,请考虑使用ThreadLocal缓存每个线程一个会话,或者使用类似于Apache共用池库的方法来维护新线程可以快速获得的初始化会话池。
https://stackoverflow.com/questions/40084563
复制相似问题