1

我可以并行连接服务器套接字和客户端套接字的许多独立 I/O 流,以便每对 I/O 流可以同时发送不同的数据吗?

如何在不增加服务器和客户端之间的套接字数量的情况下在 java 中实现这样的连接?

4

2 回答 2

0

始终有一个输入流和一个输出流,因此您不能添加更多流。

但是,正如 sje397 所评论的,您可以使用相同的流来发送“不同”的数据,您只需要想出一种方法来区分接收端的通道,这样它就可以正确地重构数据。这是一个协议设计问题。

编辑:在您的示例中,您可以有一个带有标头的数据包结构,该标头告诉数据包的类型(或通道)、数据的长度以及文件数据包的一些附加信息(如果需要)。假设长度字段是单个字节,因此您的最大数据包大小(对于字符串数据包)将为1 + 1 + 255 = 257 bytes.

当服务器读取字节时,它将检查第一个字节的数据包类型。确定是String包后,会读取长度,然后读取payload。然后该过程重复自身。

对于文件数据,很可能需要额外的标头信息,否则非字符串数据包将只是一堆字节。

这意味着您的协议将成为基于数据包的协议,因此您必须一次写入一个数据包。假设一个数据包的最大大小为 64K,那么您就可以通过以下方式发送数据(假设它是一个网络管道):

Client -> 257(S) -> 64K(D) -> 257(S) -> 64K(D) -> 257(S) -> Server 允许您在单个网络连接中交错两种不同类型的数据。

于 2015-08-29T07:43:45.427 回答
0

假设您想要快速回复控制台输入,我建议使用两个套接字流——一个用于文件数据,另一个用于用户输入。您可以使用ObjectInputStreamObjectOutputStreams来简化您的协议。只需为您的协议创建一个类,使其可序列化并将其与套接字流一起使用。

于 2015-08-29T08:22:51.593 回答