0

我有这个代码:

MemoryStream recChunk = new MemoryStream();
byte[] sizeChunkB = new byte[10];
int sizeChunk;
streamLigacao.Read(sizeChunkB, 0, sizeChunkB.Length);
sizeChunk = BitConverter.ToInt32(sizeChunkB, 0);

int timesToEnter = (int)Math.Ceiling(sizeChunk / 1024.0);

for (int i = 0; i < vezesaEntrar; i++) {
    int size = streamLigacao.Read(RecData, 0, RecData.Length);
    recChunk.Write(RecData, 0, size);
}
recChunk.Position = 0;
MemoryStream deCompressed = new MemoryStream();

using (var tmp = new SevenZipExtractor(recChunk)) {   
    tmp.ExtractFile(0, deCompressed);
}
recChunk.Close();

它返回此错误:

流无效或未找到相应的签名。

STREAMLIGACAO 是一个网络流

我究竟做错了什么?

4

1 回答 1

0

你的代码有很多问题。最重要的是:

  • Read返回读取的字节数。如果你忽略这一点,你写的比你读的多,会造成麻烦。
  • 流不会自动“重置” -recChunk在最后,因此任何读取它的人都会立即退出。你必须先做recChunk.Position = 0;
  • (int)Math.Ceiling(sizeChunk / 1024.0)可能不够准确。您真的想继续使用整数数学,而不是涉及浮点数。
  • 此外,它表明您期望的值不是 1024 的整数倍,但您假设您将读取(和写入)精确RecData.Length * timesToEnter字节的数据。这很鱼腥味。

目前尚不清楚应该包含哪些数据recChunk- 我假设它是您选择的解压缩库可以理解的有效压缩字节流。

编辑:

由于您的输入流是 TCP 流,因此上述所有内容更为重要。一个更好的读写循环看起来像这样:

var remainingBytes = sizeChunk;
var buffer = new byte[4096];

while (remainingBytes > 0)
{
  var bytesRead = streamLigacao.Read(buffer, 0, buffer.Length);
  if (bytesRead == 0) throw new InvalidOperationException("Connection closed.");

  recChunk.Write(buffer, 0, bytesRead);
}
于 2016-04-04T09:50:29.023 回答