Partager via


Deflater Class

Definition

This class provides support for general purpose compression using the popular ZLIB compression library.

[Android.Runtime.Register("java/util/zip/Deflater", DoNotGenerateAcw=true)]
public class Deflater : Java.Lang.Object
[<Android.Runtime.Register("java/util/zip/Deflater", DoNotGenerateAcw=true)>]
type Deflater = class
    inherit Object
Inheritance
Deflater
Attributes

Remarks

This class provides support for general purpose compression using the popular ZLIB compression library. The ZLIB compression library was initially developed as part of the PNG graphics standard and is not protected by patents. It is fully described in the specifications at the java.util.zip package description.

This class deflates sequences of bytes into ZLIB compressed data format. The input byte sequence is provided in either byte array or byte buffer, via one of the setInput() methods. The output byte sequence is written to the output byte array or byte buffer passed to the deflate() methods.

The following code fragment demonstrates a trivial compression and decompression of a string using Deflater and Inflater.

<blockquote>

try {
                // Encode a String into bytes
                String inputString = "blahblahblah";
                byte[] input = inputString.getBytes("UTF-8");

                // Compress the bytes
                byte[] output = new byte[100];
                Deflater compresser = new Deflater();
                compresser.setInput(input);
                compresser.finish();
                int compressedDataLength = compresser.deflate(output);
                compresser.end();

                // Decompress the bytes
                Inflater decompresser = new Inflater();
                decompresser.setInput(output, 0, compressedDataLength);
                byte[] result = new byte[100];
                int resultLength = decompresser.inflate(result);
                decompresser.end();

                // Decode the bytes into a String
                String outputString = new String(result, 0, resultLength, "UTF-8");
            } catch (java.io.UnsupportedEncodingException ex) {
                // handle
            } catch (java.util.zip.DataFormatException ex) {
                // handle
            }

</blockquote>

Added in 1.1.

Java documentation for java.util.zip.Deflater.

Portions of this page are modifications based on work created and shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.

Constructors

Deflater()

Creates a new compressor with the default compression level.

Deflater(Int32, Boolean)

Creates a new compressor using the specified compression level.

Deflater(Int32)

Creates a new compressor using the specified compression level.

Deflater(IntPtr, JniHandleOwnership)

A constructor used when creating managed representations of JNI objects; called by the runtime.

Fields

BestCompression

Compression level for best compression.

BestSpeed

Compression level for fastest compression.

DefaultCompression

Default compression level.

DefaultStrategy

Default compression strategy.

Deflated

Compression method for the deflate algorithm (the only one currently supported).

Filtered

Compression strategy best used for data consisting mostly of small values with a somewhat random distribution.

FullFlush

Compression flush mode used to flush out all pending output and reset the deflater.

HuffmanOnly

Compression strategy for Huffman coding only.

NoCompression

Compression level for no compression.

NoFlush

Compression flush mode used to achieve best compression result.

SyncFlush

Compression flush mode used to flush out all pending output; may degrade compression for some compression algorithms.

Properties

Adler

Returns the ADLER-32 value of the uncompressed data.

BytesRead

Returns the total number of uncompressed bytes input so far.

BytesWritten

Returns the total number of compressed bytes output so far.

Class

Returns the runtime class of this Object.

(Inherited from Object)
Handle

The handle to the underlying Android instance.

(Inherited from Object)
JniIdentityHashCode (Inherited from Object)
JniPeerMembers
PeerReference (Inherited from Object)
ThresholdClass

This API supports the Mono for Android infrastructure and is not intended to be used directly from your code.

ThresholdType

This API supports the Mono for Android infrastructure and is not intended to be used directly from your code.

TotalIn

Returns the total number of uncompressed bytes input so far.

TotalOut

Returns the total number of compressed bytes output so far.

Methods

Clone()

Creates and returns a copy of this object.

(Inherited from Object)
Deflate(Byte[], Int32, Int32, Int32)

Compresses the input data and fills the specified buffer with compressed data.

Deflate(Byte[], Int32, Int32)

Compresses the input data and fills specified buffer with compressed data.

Deflate(Byte[])

Compresses the input data and fills specified buffer with compressed data.

Deflate(ByteBuffer, Int32)

Compresses the input data and fills the specified buffer with compressed data.

Deflate(ByteBuffer)

Compresses the input data and fills specified buffer with compressed data.

DeflateAsync(Byte[], Int32, Int32, Int32)
DeflateAsync(Byte[], Int32, Int32)
DeflateAsync(Byte[])
DeflateAsync(ByteBuffer, Int32)
DeflateAsync(ByteBuffer)
Dispose() (Inherited from Object)
Dispose(Boolean) (Inherited from Object)
End()

Closes the compressor and discards any unprocessed input.

Equals(Object)

Indicates whether some other object is "equal to" this one.

(Inherited from Object)
Finish()

When called, indicates that compression should end with the current contents of the input buffer.

Finished()

Returns true if the end of the compressed data output stream has been reached.

GetHashCode()

Returns a hash code value for the object.

(Inherited from Object)
JavaFinalize()

Called by the garbage collector on an object when garbage collection determines that there are no more references to the object.

(Inherited from Object)
NeedsInput()

Returns true if no data remains in the input buffer.

Notify()

Wakes up a single thread that is waiting on this object's monitor.

(Inherited from Object)
NotifyAll()

Wakes up all threads that are waiting on this object's monitor.

(Inherited from Object)
Reset()

Resets deflater so that a new set of input data can be processed.

SetDictionary(Byte[], Int32, Int32)

Sets preset dictionary for compression.

SetDictionary(Byte[])

Sets preset dictionary for compression.

SetDictionary(ByteBuffer)

Sets preset dictionary for compression.

SetHandle(IntPtr, JniHandleOwnership)

Sets the Handle property.

(Inherited from Object)
SetInput(Byte[], Int32, Int32)

Sets input data for compression.

SetInput(Byte[])

Sets input data for compression.

SetInput(ByteBuffer)

Sets input data for compression.

SetLevel(Int32)

Sets the compression level to the specified value.

SetStrategy(Int32)

Sets the compression strategy to the specified value.

ToArray<T>() (Inherited from Object)
ToString()

Returns a string representation of the object.

(Inherited from Object)
UnregisterFromRuntime() (Inherited from Object)
Wait()

Causes the current thread to wait until it is awakened, typically by being <em>notified</em> or <em>interrupted</em>.

(Inherited from Object)
Wait(Int64, Int32)

Causes the current thread to wait until it is awakened, typically by being <em>notified</em> or <em>interrupted</em>, or until a certain amount of real time has elapsed.

(Inherited from Object)
Wait(Int64)

Causes the current thread to wait until it is awakened, typically by being <em>notified</em> or <em>interrupted</em>, or until a certain amount of real time has elapsed.

(Inherited from Object)

Explicit Interface Implementations

IJavaPeerable.Disposed() (Inherited from Object)
IJavaPeerable.DisposeUnlessReferenced() (Inherited from Object)
IJavaPeerable.Finalized() (Inherited from Object)
IJavaPeerable.JniManagedPeerState (Inherited from Object)
IJavaPeerable.SetJniIdentityHashCode(Int32) (Inherited from Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) (Inherited from Object)
IJavaPeerable.SetPeerReference(JniObjectReference) (Inherited from Object)

Extension Methods

JavaCast<TResult>(IJavaObject)

Performs an Android runtime-checked type conversion.

JavaCast<TResult>(IJavaObject)
GetJniTypeName(IJavaPeerable)

Gets the JNI name of the type of the instance self.

JavaAs<TResult>(IJavaPeerable)

Try to coerce self to type TResult, checking that the coercion is valid on the Java side.

TryJavaCast<TResult>(IJavaPeerable, TResult)

Try to coerce self to type TResult, checking that the coercion is valid on the Java side.

Applies to