kevinzou123 2023-06-15 09:22 采纳率: 100%
浏览 492
已结题

python并行调用java

手里有一个一直维护的 Java 计算库,能够完成业务计算。由于 Python 的生态圈优势(数据 I/O、绘图等工具箱),目前主要的数据分析和可视化代码是在 Python 中完成的。Python 调用 Java 的 Jar 库,必须通过 Jpype 或者 JCC 的形式调用,这两个都必须在使用前启动 java 虚拟机,然后 java 函数在这个虚拟机上执行。

现在的问题是,随着计算场景的复杂程度提高,Python 调用 Jar 计算的速度已经远远够不上需求,目前算2个小时的场景数据需要一天的时间。

解决问题的几个思路:
一个是在 python 中实现对多进程调用 Java,完成数据的并行计算和数据的并行 I/O;
一种是使用 C++重新写 java 的库,但是 python 调用 C 是否能实现上述多线程的功能?
还有一个思路是在 java 中完成多线程的计算,但是需要解决 java 并行写数据的问题(数据库?还是 HDF5 文件?)

  • 写回答

24条回答 默认 最新

  • 技术宅program 2023-06-15 09:46
    关注

    优先考虑使用Python的multiprocessing库调用Java库(较高拓展性),其次 C++重写Java库(工作量大,但可以发挥C++的优势),然后在考虑Java多线程并行计算和写库

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(23条)

报告相同问题?

问题事件

  • 系统已结题 6月29日
  • 已采纳回答 6月21日
  • 创建了问题 6月15日

悬赏问题

  • ¥20 python爬虫遇到空文本取不出来
  • ¥15 x264库中预测模式字IPM、运动向量差MVD、量化后的DCT系数的位置
  • ¥15 curl 命令调用正常,程序调用报 java.net.ConnectException: connection refused
  • ¥20 关于web前端如何播放二次加密m3u8视频的问题
  • ¥15 使用百度地图api 位置函数报错?
  • ¥15 metamask如何添加TRON自定义网络
  • ¥66 关于川崎机器人调速问题
  • ¥15 winFrom界面无法打开
  • ¥30 crossover21 ARM64版本安装软件问题
  • ¥15 mymetaobjecthandler没有进入