首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >一个renjin R脚本引擎实例能被多线程并行使用吗?

一个renjin R脚本引擎实例能被多线程并行使用吗?
EN

Stack Overflow用户
提问于 2016-10-17 10:54:50
回答 1查看 165关注 0票数 0

作为人源Java库用户的新手,我计划使用renjin ScriptEngine并行执行多线程上的计算。显然,在每个线程上初始化一个renjin ScriptEngine实例是很好的,然后初始化的renjin实例可以由其所属线程使用。

然而,由于一个renjin实例的初始化过程需要很长时间,我突然想到了一个问题:多个线程能否共享一个enjin ScriptEngine实例并并行调用它?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-10-17 12:53:09

不能使用共享RenjinSession同时计算多个R表达式。从技术上讲,如果您验证所调用的R函数中没有一个影响会话级别的状态,则可以这样做,其中包括:

  • 修改R全球环境
  • 生成随机数
  • 更新选项()
  • 触发对共享的、未评估的承诺的评估

但是所有这些东西在基和统计包中的R函数中是很常见的。

如果希望减少初始化新RenjinSessions的开销,请考虑使用ThreadLocal缓存每个线程一个会话,或者使用类似于Apache共用池库的方法来维护新线程可以快速获得的初始化会话池。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40084563

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档