Próbuję skompresować i rozpakować strumień przy użyciu Compression.DeflateStream. Kompresowanie wydaje się działać poprawnie, ponieważ poniższy kod kompresuje moją Stream do tablicy o długości 110 bajtów. Jednak odczyt strumienia dekompresji spowoduje pusty ciąg znaków.Kompresja i dekompresja strumienia z kompresją.DeflateStream
class Program
{
static void Main(string[] args)
{
// Compress a random string value
string value = Path.GetRandomFileName();
byte[] compressedBytes;
using (var writer = new StreamWriter(new MemoryStream()))
{
writer.Write(value);
writer.Flush();
writer.BaseStream.Position = 0;
compressedBytes = Compress(writer.BaseStream);
}
// Decompress compressed bytes
Stream decompressedStream = Decompress(compressedBytes);
// here already applies: decompressedStream.Length == 0
using (var reader = new StreamReader(decompressedStream))
{
string decompressedValue = reader.ReadToEnd();
if (value == decompressedValue)
Console.WriteLine("Success");
else
Console.WriteLine("Failed");
}
}
private static byte[] Compress(Stream input)
{
using (var compressStream = new MemoryStream())
using (var compressor = new DeflateStream(compressStream, CompressionMode.Compress))
{
input.CopyTo(compressor);
return compressStream.ToArray();
}
}
private static Stream Decompress(byte[] input)
{
var output = new MemoryStream();
using (var compressStream = new MemoryStream(input))
using (var decompressor = new DeflateStream(compressStream, CompressionMode.Decompress))
decompressor.CopyTo(output);
output.Position = 0;
return output;
}
}
Czy ktoś może mi pomóc w tej sprawie? Wielkie dzięki.
To działa. Wielkie dzięki – greijner
Musisz wywołać, że jeśli nazwiesz "Flush" zamiast "Close", to nie działa. Myślałem, że 'Close' nazywając' Flush' wewnętrznie, to dlaczego to działa, ale nie. –
@Luke: od [dokumentacji dla 'DeflateStream.Flush()'] (https://msdn.microsoft.com/en-us/library/system.io.compression.deflatestream.flush (v = vs.110) .aspx): _ "Obecna implementacja tej metody nie powoduje opróżnienia bufora wewnętrznego, bufor wewnętrzny jest przepłukiwany, gdy obiekt jest usuwany." _ Dlaczego jest to projekt, 'Stream.Flush()' ma na celu przepłucz wewnętrzne buforowanie, ale strumień deflacji nie może zostać sfinalizowany, dopóki nie będzie wiedział, że jesteś na pozycji _end_, co jest możliwe tylko wtedy, gdy strumień jest zamknięty. –