【问题标题】:Socket bulk reading returned an array of zeros套接字批量读取返回一个零数组
【发布时间】:2016-04-26 04:01:36
【问题描述】:

我一直在编写一个简单的文件传输程序,它打开与服务器的 TCP 连接,协商文件传输的条款(通过 TCP)并将文件从客户端流式传输到服务器。问题是大文件几乎总是损坏。我记录了套接字InputStreamOutputStream,发现虽然数据一开始是匹配的,但在几千字节之后发生了有趣的不同步。

在某个时刻,接收套接字开始读取0,而发送套接字继续发送文件数据。

例子:

Server: ..., -75, 82, 34, -109, 50, -51, 52, 9, -14, -70,...
Client: ..., -75, 82, 34, -109, 50,   0,  0, 0,   0,   0,...

不过过了一会儿就恢复了

..., 0, 0, 0, 0, 0, -51, 52, 9, -14, -70,...

您会注意到它从中断的地方继续。唯一的问题是现在我的文件中有一堆零,并且流的结尾不会被记录到文件中(因为文件长度是提前发送的)。

注意:这似乎只在某些时候发生(通常情况下)

流代码本身:

发件人:

<header stuff, I checked it works fine>

long dataLeft = 0;
while(dataLeft < packet.payloadSize){
    packet.remaining = packet.payloadSize-dataLeft;
    byte[] temp = new byte[packet.remaining<8192?(int)packet.remaining:8192];
    packet.inStream.read(temp);
    stream.write(temp);
    dataLeft+=temp.length;
}

stream.flush();

<Rest of the code>

接收者:

public boolean streamPayload(OutputStream out) throws IOException{
    long dataLeft = 0;
    while(dataLeft < payloadSize){
        remaining = payloadSize-dataLeft;
        byte[] temp = new byte[remaining<8192?(int)remaining:8192];
        inStream.read(temp);
        out.write(temp);
        dataLeft+=temp.length;
    }
    return true;
}

long dataLeft 充当索引顺便说一句。

有谁知道为什么会发生这种情况以及如何解决/补偿问题?我知道我无法判断是否打算使用零,所以我不能只通过观察输出来听问题。

【问题讨论】:

  • 因为所有发送/接收函数可能发送/接收少于请求的字节数。例如,inStream.read(temp) 读取的字节数可能少于temp.length。所以,这个数组的尾部元素将等于零。
  • 这是我的问题。谢谢!

标签: java sockets tcp file-transfer


【解决方案1】:

我不知道这是否能解决您的问题,但您做错的一件事是忽略了传输的数据量。

InputStream in = //from somewhere
OutputStream out = //to somewhere
byte[] buffer = new byte[8192];
int read = -1;
while ((read = in.read(buffer)) > -1) {
    out.write(buffer, 0, read);
}
out.close();
int.close();

您可能在没有收到任何数据的情况下读取数据,然后写入空的 8192 字节缓冲区,因为您没有检查是否有任何内容通过。

【讨论】:

  • 这几乎肯定是正确的答案。 OP:如果您忽略来自 in.read() 的返回值,您损坏您的数据。
  • 谢谢!我明白了,我可能会要求它填充一个 8K 缓冲区,但它可能不会一直填充它。再次感谢。
猜你喜欢
  • 2021-05-14
  • 2015-05-24
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多