Skip to main content

Compressing Streams in .Net



Namespace: System.IO.Compression

There are two types of compression streams, GZip and Deflate. GZip leaves a standard header information block that can be used by the tools like Gzip to decompress the information. Deflate does not leaves any header information thus it is only decompressed by the respective application only.

Both streams can only compress 4GB of uncompressed data.

FileStream source = new FileStream(@“C:\file.dat”);
FileStream destination = new FileStream(@“C:\file.gzip”);

GZipStream Gs = new GZipStream(destination, CompressionMode.Compress);

int b = source.ReadByte();

While(b!=-1)
{
                Gs.WriteByte((byte)b);
                b = source.ReadByte();
}


And to decompress a compressed file:

FileStream source = new FileStream(@“C:\file.gzip”);  //reversed
FileStream destination = new FileStream(@“C:\file.dat”);

GZipStream Gs = new GZipStream(destination, CompressionMode.Decompress);

int b = source.ReadByte();

While(b!=-1)
{
                Gs.WriteByte((byte)b);
                b = source.ReadByte();
}

GZip Properties
Name
Description
BaseStream
Gets a reference to the underlying stream.
CanRead
Gets a value indicating whether the stream supports reading while decompressing a file. (Overrides .CanRead.)
CanSeek
Gets a value indicating whether the stream supports seeking. (Overrides .CanSeek.)
CanTimeout
Gets a value that determines whether the current stream can time out. (Inherited from Stream.)
CanWrite
Gets a value indicating whether the stream supports writing. (Overrides .CanWrite.)
Length
Throws a NotSupportedException.
Position
Throws a NotSupportedException.
ReadTimeout
Gets or sets a value that determines how long the stream will attempt to read before timing out. (Inherited from Stream.)
WriteTimeout
Gets or sets a value that determines how long the stream will attempt to write before timing out. (Inherited from Stream.)

Public Methods:

Name
Description
BeginRead
Begins an asynchronous read operation. (Overrides .BeginRead(Byte[](), Int32, Int32, AsyncCallback, Object).)
BeginWrite
Begins an asynchronous write operation. (Overrides .BeginWrite(Byte[](), Int32, Int32, AsyncCallback, Object).)
Close
Closes the current stream and releases any resources (such as sockets and file handles) associated with the current stream. (Inherited from Stream.)
EndRead
Waits for the pending asynchronous read to complete. (Overrides .EndRead(IAsyncResult).)
EndWrite
Handles the end of an asynchronous write operation. (Overrides .EndWrite(IAsyncResult).)
Flush
Flushes the contents of the internal buffer of the current GZipStream object to the underlying stream. (Overrides .Flush().)
Read
Reads a number of decompressed bytes into the specified byte array. (Overrides .Read(Byte[](), Int32, Int32).)
ReadByte
Reads a byte from the stream and advances the position within the stream by one byte, or returns -1 if at the end of the stream. (Inherited from Stream.)
Seek
Throws a NotSupportedException.
SetLength
Throws a NotSupportedException.
Write
Writes compressed bytes to the underlying stream from the specified byte array. (Overrides .Write(Byte[](), Int32, Int32).)
WriteByte
Writes a byte to the current position in the stream and advances the position within the stream by one byte. (Inherited from Stream.)

Comments

Popular posts from this blog

Culture Information and Localization in .NET

Namespace: System.Globalization CultureInfo Class:                 It provides information like the Format of numbers and dates, Culture’s Calendar, Culture’s language and sublanguage (if applicable), Country and region of the culture. The Basic use of CultureInfo class is shown here: • How string Comparisons are performed • How Number Comparison & Formats are performed • Date Comparison and Formats. • How resources are retrieved and used. Cultures are grouped into three categories: Invariant Culture : It’s Culture Insensitive. It can be used to build some trial application. It can be also used to build an application with hard-coded expiry date that ignores cultures. But using it for every comparison will be incorrect and inappropriate. Neutral Culture : English(en), Frensh(fr), and Spanish(sp). A neutral culture is related to language but it’s not related to specific regi...

Concept of App Domain in .Net

Creating Application Domains: Application domain is just like process, provides separate memory space, and isolates from other code. But it’s quite light weight. It also provides the following advantages: 1-       Reliability : If a domain crashes, it can be unloaded. Hence doesn’t affect the other assemblies. 2-       Efficiency : Loading all assemblies in one domain can be cumbersome and can make the process heavy but Appdomains are efficient in this manner. Important properties of AppDomain: ApplicationIdentity , ApplicationTrust , BaseDirectory , CurrentDomain , DomainManager , DomainDirectory , Evidence , FriendlyName , ID , RelativeSearchPath , SetupInformation , ShadowCopyFiles . Important methods of AppDomain: ApplyPolicy , CreateCOMInstanceFrom , CreateDomain , CreateInstance (Assembly). To create an AppDomain: AppDomain adomain = AppDomain.CreateDomain(“D”); To execute an assembly:...

Asynchronous Execution in ASP.NET

Asynchronous Execution: Two ways either implement IHTTPAsyncHandler interface or in ASP.NET 2.0 set <%@ Page Async=”true” %>. The second option implements IHTTPAsyncHandler interface automatically for the page when parsed or compiled. AddOnPreRenderCompleteAsync ( new BeginEventHandler(BeginTask), new EndEventHandler(EndTask)); AddOnPreRenderCompleteAsync() shoud be called in Page_load. The BeginEventHandler and EndEventHandler are delegates defined as follows: IAsyncResult BeginEventHandler( object sender, EventArgs e, AsyncCallback cb, object state) void EndEventHandler( IAsyncResult ar) AsyncProcess starts and completes between PreRender and PreRenderComplete. Other way to perform Async Task is using AsyncPageTask structure. It also allows multiple tasks to execute simultaneously. void Page_Load (object sender, EventArgs e) { PageAsyncTask task = new PageAsyncTask( new BeginEventHandler(BeginTask), new EndEventH...