gpt4 book ai didi

java - 我应该如何从 JNI 调用中流式传输大型二进制结果?

转载 作者:行者123 更新时间:2023-11-30 11:50:57 26 4
gpt4 key购买 nike

我通过创建一个外部 C 进程来在 Java 和一些 C 代码之间执行 IPC,该进程采用一些命令行参数并将其结果写入标准输出。这是在服务器应用程序内部,因此返回的数据需要直接反馈到 HttpServletResponse 的 OutputStream 中,我目前正在使用一个简单的 Apache commons IOUtils.copy(inputStream, outputStream) .当前的解决方案很方便,因为外部进程可以生成任意大的响应而无需消耗任意数量的内存。不幸的是,生成外部流程的成本以及实际流程逻辑所需的所有设置,使得小型作业的开销无法接受。所以我想切换到 JNI,这将消除外部进程开销,并允许这些任务的大部分设置在服务器启动时静态执行一次。

但我现在想知道如何保留响应的当前流特性——我不想简单地让 JNI 调用返回一个字节数组甚至一个 ByteBuffer,因为我想限制内存使用并且低的。那么,有哪些技术可用于调用 C 逻辑并以某种方式返回基本上任意大的字节数组,使我可以将它们放入 OutputStream 而不会消耗任意大量内存,也不会为设置 C 环境带来太多开销。

FWIW,这段 C 代码基本上是在一堆记录上运行传入的 Lua 脚本,并返回每条记录的输出。

想到的主要方法是将 OutputStream 传递到 native 方法,并在 C 代码生成其响应时使用 JNI 反射间歇性地对其调用 write。我缺少更好的选择吗?文件?零龙?

最佳答案

您可以让您的 JNI 方法返回一个带有读取回调的 InputStream 到 JNI,但我认为按照您的建议将 OutputStream 传递到 JNI 是一个更简洁的解决方案。

关于java - 我应该如何从 JNI 调用中流式传输大型二进制结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7700551/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com