2

我正在用 Java 开发一个客户端-服务器系统。我通过带有序列化对象的 TCP 通道发送消息。

我还需要发送文件。我可以定义自己的自定义消息类:

public class SendFile implements Serializable {
    private byte[] fileContents;

    ...
}

并发送它。如果我们有一个大文件,这会带来一个问题,据我了解,它会在将文件发送到另一端之前尝试将所有内容都保存在内存中。

我已经阅读过,Externalizable但如果在通过 TCP 通道发送文件之前仍在将文件读取到我所有计算机的内存中,那也不会更好。我想要一些“懒惰”的方式来做到这一点(当我通过网络发送它时从磁盘读取它,并从内存中丢弃已经读取的内容)。

处理这个问题的最干净的方法是什么?在最坏的情况下,我可以把它分成小块,但如果可能的话,我想避免它。

编辑:

当然,我可以在文件上打开一个流并“发送”。但这意味着以不同的方式处理发送文件和所有其他消息,这是我希望避免的。

谢谢

4

2 回答 2

2

绕过它的一种方法是使用。流式处理方法不会将全部内容加载到内存中。您可以打开两个流,来自要通过网络发送的对象的输入流和用于 TCP 套接字连接的 输出流。

在java中,InputStreamOutputStream。支持字节的读写。

您可以定义缓冲区大小(字节数组)。使用读取(从文件)内容到该缓冲区, InputStream.read(byte[] b)并使用写入(到 TCP 套接字)相同的缓冲区到输出流OutputStream.write(byte[] b)

于 2012-02-28T10:24:35.070 回答
0

您可以直接在缓冲区中读取 Java 文件并通过网络发送该缓冲区,而不是使用 Java 序列化。为什么在 b/w 中涉及 java 序列化和复杂的东西。使用简单的 n/w 程序,您将能够发送您的文件。

于 2012-03-02T19:13:30.247 回答