Udostępnij za pośrednictwem


CharsetDecoder Class

Definition

An engine that can transform a sequence of bytes in a specific charset into a sequence of sixteen-bit Unicode characters.

[Android.Runtime.Register("java/nio/charset/CharsetDecoder", DoNotGenerateAcw=true)]
public abstract class CharsetDecoder : Java.Lang.Object
[<Android.Runtime.Register("java/nio/charset/CharsetDecoder", DoNotGenerateAcw=true)>]
type CharsetDecoder = class
    inherit Object
Inheritance
CharsetDecoder
Attributes

Remarks

An engine that can transform a sequence of bytes in a specific charset into a sequence of sixteen-bit Unicode characters.

"steps">

The input byte sequence is provided in a byte buffer or a series of such buffers. The output character sequence is written to a character buffer or a series of such buffers. A decoder should always be used by making the following sequence of method invocations, hereinafter referred to as a decoding operation:

<ol>

<li>

Reset the decoder via the #reset reset method, unless it has not been used before;

</li>

<li>

Invoke the #decode decode method zero or more times, as long as additional input may be available, passing false for the endOfInput argument and filling the input buffer and flushing the output buffer between invocations;

</li>

<li>

Invoke the #decode decode method one final time, passing true for the endOfInput argument; and then

</li>

<li>

Invoke the #flush flush method so that the decoder can flush any internal state to the output buffer.

</li>

</ol>

Each invocation of the #decode decode method will decode as many bytes as possible from the input buffer, writing the resulting characters to the output buffer. The #decode decode method returns when more input is required, when there is not enough room in the output buffer, or when a decoding error has occurred. In each case a CoderResult object is returned to describe the reason for termination. An invoker can examine this object and fill the input buffer, flush the output buffer, or attempt to recover from a decoding error, as appropriate, and try again.

"ce">

There are two general types of decoding errors. If the input byte sequence is not legal for this charset then the input is considered malformed. If the input byte sequence is legal but cannot be mapped to a valid Unicode character then an unmappable character has been encountered.

"cae">

How a decoding error is handled depends upon the action requested for that type of error, which is described by an instance of the CodingErrorAction class. The possible error actions are to CodingErrorAction#IGNORE ignore the erroneous input, CodingErrorAction#REPORT report the error to the invoker via the returned CoderResult object, or CodingErrorAction#REPLACE replace the erroneous input with the current value of the replacement string. The replacement

has the initial value "&#92;uFFFD";

its value may be changed via the #replaceWith(java.lang.String) replaceWith method.

The default action for malformed-input and unmappable-character errors is to CodingErrorAction#REPORT report them. The malformed-input error action may be changed via the #onMalformedInput(CodingErrorAction) onMalformedInput method; the unmappable-character action may be changed via the #onUnmappableCharacter(CodingErrorAction) onUnmappableCharacter method.

This class is designed to handle many of the details of the decoding process, including the implementation of error actions. A decoder for a specific charset, which is a concrete subclass of this class, need only implement the abstract #decodeLoop decodeLoop method, which encapsulates the basic decoding loop. A subclass that maintains internal state should, additionally, override the #implFlush implFlush and #implReset implReset methods.

Instances of this class are not safe for use by multiple concurrent threads.

Added in 1.4.

Java documentation for java.nio.charset.CharsetDecoder.

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

CharsetDecoder(Charset, Single, Single)

Initializes a new decoder.

CharsetDecoder(IntPtr, JniHandleOwnership)

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

Properties

Class

Returns the runtime class of this Object.

(Inherited from Object)
Handle

The handle to the underlying Android instance.

(Inherited from Object)
IsAutoDetecting

Tells whether or not this decoder implements an auto-detecting charset.

IsCharsetDetected

Tells whether or not this decoder has yet detected a charset&nbsp;&nbsp;(optional operation).

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.

Methods

AverageCharsPerByte()

Returns the average number of characters that will be produced for each byte of input.

Charset()

Returns the charset that created this decoder.

Clone()

Creates and returns a copy of this object.

(Inherited from Object)
Decode(ByteBuffer, CharBuffer, Boolean)

Decodes as many bytes as possible from the given input buffer, writing the results to the given output buffer.

Decode(ByteBuffer)

Convenience method that decodes the remaining content of a single input byte buffer into a newly-allocated character buffer.

DecodeLoop(ByteBuffer, CharBuffer)

Decodes one or more bytes into one or more characters.

DetectedCharset()

Retrieves the charset that was detected by this decoder&nbsp;&nbsp;(optional operation).

Dispose() (Inherited from Object)
Dispose(Boolean) (Inherited from Object)
Equals(Object)

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

(Inherited from Object)
Flush(CharBuffer)

Flushes this decoder.

GetHashCode()

Returns a hash code value for the object.

(Inherited from Object)
ImplFlush(CharBuffer)

Flushes this decoder.

ImplOnMalformedInput(CodingErrorAction)

Reports a change to this decoder's malformed-input action.

ImplOnUnmappableCharacter(CodingErrorAction)

Reports a change to this decoder's unmappable-character action.

ImplReplaceWith(String)

Reports a change to this decoder's replacement value.

ImplReset()

Resets this decoder, clearing any charset-specific internal state.

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)
MalformedInputAction()

Returns this decoder's current action for malformed-input errors.

MaxCharsPerByte()

Returns the maximum number of characters that will be produced for each byte of input.

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)
OnMalformedInput(CodingErrorAction)

Changes this decoder's action for malformed-input errors.

OnUnmappableCharacter(CodingErrorAction)

Changes this decoder's action for unmappable-character errors.

Replacement()

Returns this decoder's replacement value.

ReplaceWith(String)

Changes this decoder's replacement value.

Reset()

Resets this decoder, clearing any internal state.

SetHandle(IntPtr, JniHandleOwnership)

Sets the Handle property.

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

Returns a string representation of the object.

(Inherited from Object)
UnmappableCharacterAction()

Returns this decoder's current action for unmappable-character errors.

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