UTF8Encoding.GetDecoder Método

Definição

Obtém um decodificador que converte uma sequência de bytes codificados em UTF-8 em uma sequência de caracteres Unicode.Obtains a decoder that converts a UTF-8 encoded sequence of bytes into a sequence of Unicode characters.

public:
 override System::Text::Decoder ^ GetDecoder();
public override System.Text.Decoder GetDecoder ();
override this.GetDecoder : unit -> System.Text.Decoder
Public Overrides Function GetDecoder () As Decoder

Retornos

Um decodificador que converte uma sequência de bytes codificados em UTF-8 em uma sequência de caracteres Unicode.A decoder that converts a UTF-8 encoded sequence of bytes into a sequence of Unicode characters.

Exemplos

O exemplo a seguir usa o método GetDecoder para obter um decodificador UTF-8.The following example uses the GetDecoder method to obtain a UTF-8 decoder. O decodificador converte uma sequência de bytes em uma sequência de caracteres.The decoder converts a sequence of bytes into a sequence of characters.

using namespace System;
using namespace System::Text;
using namespace System::Collections;
int main()
{
   array<Char>^chars;
   array<Byte>^bytes = {99,204,128,234,130,160};
   Decoder^ utf8Decoder = Encoding::UTF8->GetDecoder();
   int charCount = utf8Decoder->GetCharCount( bytes, 0, bytes->Length );
   chars = gcnew array<Char>(charCount);
   int charsDecodedCount = utf8Decoder->GetChars( bytes, 0, bytes->Length, chars, 0 );
   Console::WriteLine( "{0} characters used to decode bytes.", charsDecodedCount );
   Console::Write( "Decoded chars: " );
   IEnumerator^ myEnum = chars->GetEnumerator();
   while ( myEnum->MoveNext() )
   {
      Char c = safe_cast<Char>(myEnum->Current);
      Console::Write( "[{0}]", c.ToString() );
   }

   Console::WriteLine();
}

using System;
using System.Text;

class UTF8EncodingExample {
    public static void Main() {
        Char[] chars;
        Byte[] bytes = new Byte[] {
            99, 204, 128, 234, 130, 160
        };

        Decoder utf8Decoder = Encoding.UTF8.GetDecoder();

        int charCount = utf8Decoder.GetCharCount(bytes, 0, bytes.Length);
        chars = new Char[charCount];
        int charsDecodedCount = utf8Decoder.GetChars(bytes, 0, bytes.Length, chars, 0);

        Console.WriteLine(
            "{0} characters used to decode bytes.", charsDecodedCount
        );

        Console.Write("Decoded chars: ");
        foreach (Char c in chars) {
            Console.Write("[{0}]", c);
        }
        Console.WriteLine();
    }
}
Imports System.Text

Class UTF8EncodingExample
    
    Public Shared Sub Main()
        Dim chars() As Char
        Dim bytes() As Byte = {99, 204, 128, 234, 130, 160}
        
        Dim utf8Decoder As Decoder = Encoding.UTF8.GetDecoder()
        
        Dim charCount As Integer = utf8Decoder.GetCharCount(bytes, 0, bytes.Length)
        chars = New Char(charCount - 1) {}
        Dim charsDecodedCount As Integer = utf8Decoder.GetChars( _
            bytes, 0, bytes.Length, chars, 0 _
        )
        
        Console.WriteLine("{0} characters used to decode bytes.", charsDecodedCount)
        
        Console.Write("Decoded chars: ")
        Dim c As Char
        For Each c In  chars
            Console.Write("[{0}]", c)
        Next c
        Console.WriteLine()
    End Sub
End Class

Comentários

O método Decoder.GetChars converte blocos sequenciais de bytes em blocos sequenciais de caracteres, de maneira semelhante ao método GetChars dessa classe.The Decoder.GetChars method converts sequential blocks of bytes into sequential blocks of characters, in a manner similar to the GetChars method of this class. No entanto, um Decoder mantém informações de estado entre chamadas para que possa decodificar corretamente Sequências de bytes que abranjam blocos.However, a Decoder maintains state information between calls so it can correctly decode byte sequences that span blocks. O Decoder também preserva os bytes à direita no final dos blocos de dados e usa os bytes à direita na próxima operação de decodificação.The Decoder also preserves trailing bytes at the end of data blocks and uses the trailing bytes in the next decoding operation. Portanto, GetDecoder e GetEncoder são úteis para operações de arquivo e transmissão de rede, pois essas operações geralmente lidam com blocos de dados em vez de um fluxo de dados completo.Therefore, GetDecoder and GetEncoder are useful for network transmission and file operations, because those operations often deal with blocks of data instead of a complete data stream.

Se a detecção de erros estiver habilitada, ou seja, o parâmetro throwOnInvalidCharacters do Construtor for definido como true, a detecção de erros também será habilitada no Decoder retornado por esse método.If error detection is enabled, that is, the throwOnInvalidCharacters parameter of the constructor is set to true, error detection is also enabled in the Decoder returned by this method. Se a detecção de erros estiver habilitada e uma sequência inválida for encontrada, o estado do decodificador será indefinido e o processamento deverá parar.If error detection is enabled and an invalid sequence is encountered, the state of the decoder is undefined and processing must stop.

Aplica-se a

Veja também