UTF7Encoding.GetBytes Método

Definição

Codifica um conjunto de caracteres em uma sequência de bytes.

Sobrecargas

Nome Description
GetBytes(Char*, Int32, Byte*, Int32)

Codifica um conjunto de caracteres começando no ponteiro de caractere especificado em uma sequência de bytes que são armazenados a partir do ponteiro de bytes especificado.

GetBytes(Char[], Int32, Int32, Byte[], Int32)

Codifica um conjunto de caracteres da matriz de caracteres especificada na matriz de bytes especificada.

GetBytes(String, Int32, Int32, Byte[], Int32)

Codifica um conjunto de caracteres do especificado String na matriz de bytes especificada.

GetBytes(Char*, Int32, Byte*, Int32)

Importante

Esta API não está em conformidade com CLS.

Codifica um conjunto de caracteres começando no ponteiro de caractere especificado em uma sequência de bytes que são armazenados a partir do ponteiro de bytes especificado.

public:
 override int GetBytes(char* chars, int charCount, System::Byte* bytes, int byteCount);
[System.CLSCompliant(false)]
[System.Security.SecurityCritical]
public override int GetBytes(char* chars, int charCount, byte* bytes, int byteCount);
[System.CLSCompliant(false)]
[System.Runtime.InteropServices.ComVisible(false)]
public override int GetBytes(char* chars, int charCount, byte* bytes, int byteCount);
[System.CLSCompliant(false)]
[System.Security.SecurityCritical]
[System.Runtime.InteropServices.ComVisible(false)]
public override int GetBytes(char* chars, int charCount, byte* bytes, int byteCount);
[System.CLSCompliant(false)]
public override int GetBytes(char* chars, int charCount, byte* bytes, int byteCount);
[<System.CLSCompliant(false)>]
[<System.Security.SecurityCritical>]
override this.GetBytes : nativeptr<char> * int * nativeptr<byte> * int -> int
[<System.CLSCompliant(false)>]
[<System.Runtime.InteropServices.ComVisible(false)>]
override this.GetBytes : nativeptr<char> * int * nativeptr<byte> * int -> int
[<System.CLSCompliant(false)>]
[<System.Security.SecurityCritical>]
[<System.Runtime.InteropServices.ComVisible(false)>]
override this.GetBytes : nativeptr<char> * int * nativeptr<byte> * int -> int
[<System.CLSCompliant(false)>]
override this.GetBytes : nativeptr<char> * int * nativeptr<byte> * int -> int

Parâmetros

chars
Char*

Um ponteiro para o primeiro caractere a ser codificado.

charCount
Int32

O número de caracteres a serem codificados.

bytes
Byte*

Um ponteiro para o local no qual começar a gravar a sequência resultante de bytes.

byteCount
Int32

O número máximo de bytes a serem gravados.

Retornos

O número real de bytes gravados no local indicado por bytes.

Atributos

Exceções

chars é null (Nothing).

-ou-

bytes é null (Nothing).

charCount ou byteCount é menor que zero.

byteCount é menor que o número resultante de bytes.

Ocorreu um fallback (consulte Codificação doCharacter em .NET para obter uma explicação mais completa).

-e-

EncoderFallback é definido como EncoderExceptionFallback.

Comentários

Para calcular o tamanho exato da matriz exigido para GetBytes armazenar os bytes resultantes GetByteCount, o aplicativo usa . Para calcular o tamanho máximo da matriz, o aplicativo deve usar GetMaxByteCount. O GetByteCount método geralmente permite a alocação de menos memória, enquanto o GetMaxByteCount método geralmente é executado mais rapidamente.

Os dados a serem convertidos, como dados lidos de um fluxo, podem estar disponíveis apenas em blocos sequenciais. Nesse caso, ou se a quantidade de dados é tão grande que precisa ser dividida em blocos menores, o aplicativo deve usar o Decoder método ou o Encoder fornecido pelo GetDecoder método ou pelo GetEncoder método, respectivamente.

Note

UTF7Encoding não fornece detecção de erros. Caracteres inválidos são codificados como um caractere base 64 modificado. Por motivos de segurança, recomendamos que seus aplicativos usem UTF8EncodingUnicodeEncodingou UTF32Encoding habilitem a detecção de erros.

Confira também

Aplica-se a

GetBytes(Char[], Int32, Int32, Byte[], Int32)

Codifica um conjunto de caracteres da matriz de caracteres especificada na matriz de bytes especificada.

public:
 override int GetBytes(cli::array <char> ^ chars, int charIndex, int charCount, cli::array <System::Byte> ^ bytes, int byteIndex);
public override int GetBytes(char[] chars, int charIndex, int charCount, byte[] bytes, int byteIndex);
override this.GetBytes : char[] * int * int * byte[] * int -> int
Public Overrides Function GetBytes (chars As Char(), charIndex As Integer, charCount As Integer, bytes As Byte(), byteIndex As Integer) As Integer

Parâmetros

chars
Char[]

A matriz de caracteres que contém o conjunto de caracteres a serem codificados.

charIndex
Int32

O índice do primeiro caractere a ser codificado.

charCount
Int32

O número de caracteres a serem codificados.

bytes
Byte[]

A matriz de bytes para conter a sequência resultante de bytes.

byteIndex
Int32

O índice no qual começar a gravar a sequência resultante de bytes.

Retornos

O número real de bytes gravados em bytes.

Exceções

chars é null (Nothing).

-ou-

bytes é null (Nothing).

charIndex ou charCount ou byteIndex é menor que zero.

-ou-

charIndex e charCount não denotar um intervalo válido em chars.

-ou-

byteIndex não é um índice válido em bytes.

bytes não tem capacidade suficiente do byteIndex final da matriz para acomodar os bytes resultantes.

Ocorreu um fallback (consulte Codificação doCharacter em .NET para obter uma explicação mais completa).

-e-

EncoderFallback é definido como EncoderExceptionFallback.

Exemplos

O exemplo de código a seguir demonstra como usar o GetBytes método para codificar um intervalo de caracteres de um String e armazenar os bytes codificados em um intervalo de elementos em uma matriz de bytes.

using System;
using System.Text;

class UTF7EncodingExample {
    public static void Main() {
        Byte[] bytes;
        // Unicode characters.
        Char[] chars = new Char[] {
            '\u0023', // #
            '\u0025', // %
            '\u03a0', // Pi
            '\u03a3'  // Sigma
        };
        
        UTF7Encoding utf7 = new UTF7Encoding();
        
        int byteCount = utf7.GetByteCount(chars, 1, 2);
        bytes = new Byte[byteCount];
        int bytesEncodedCount = utf7.GetBytes(chars, 1, 2, bytes, 0);
        
        Console.WriteLine(
            "{0} bytes used to encode characters.", bytesEncodedCount
        );

        Console.Write("Encoded bytes: ");
        foreach (Byte b in bytes) {
            Console.Write("[{0}]", b);
        }
        Console.WriteLine();
    }
}
Imports System.Text
Imports Microsoft.VisualBasic.strings

Class UTF7EncodingExample
    
    Public Shared Sub Main()
        Dim bytes() As Byte
        ' Unicode characters.
        ' ChrW(35)  = #
        ' ChrW(37)  = %
        ' ChrW(928) = Pi
        ' ChrW(931) = Sigma
        Dim chars() As Char = {ChrW(35), ChrW(37), ChrW(928), ChrW(931)}
        
        Dim utf7 As New UTF7Encoding()
        
        Dim byteCount As Integer = utf7.GetByteCount(chars, 1, 2)
        bytes = New Byte(byteCount - 1) {}
        Dim bytesEncodedCount As Integer = utf7.GetBytes(chars, 1, 2, bytes, 0)
        
        Console.WriteLine("{0} bytes used to encode characters.", bytesEncodedCount)
        
        Console.Write("Encoded bytes: ")
        Dim b As Byte
        For Each b In  bytes
            Console.Write("[{0}]", b)
        Next b
        Console.WriteLine()
    End Sub
End Class

Comentários

Para calcular o tamanho exato da matriz exigido para GetBytes armazenar os bytes resultantes GetByteCount, o aplicativo usa . Para calcular o tamanho máximo da matriz, o aplicativo deve usar GetMaxByteCount. O GetByteCount método geralmente permite a alocação de menos memória, enquanto o GetMaxByteCount método geralmente é executado mais rapidamente.

Os dados a serem convertidos, como dados lidos de um fluxo, podem estar disponíveis apenas em blocos sequenciais. Nesse caso, ou se a quantidade de dados é tão grande que precisa ser dividida em blocos menores, o aplicativo deve usar o Decoder método ou o Encoder fornecido pelo GetDecoder método ou pelo GetEncoder método, respectivamente.

Note

UTF7Encoding não fornece detecção de erros. Caracteres inválidos são codificados como um caractere base 64 modificado. Por motivos de segurança, recomendamos que seus aplicativos usem UTF8EncodingUnicodeEncodingou UTF32Encoding habilitem a detecção de erros.

Confira também

Aplica-se a

GetBytes(String, Int32, Int32, Byte[], Int32)

Codifica um conjunto de caracteres do especificado String na matriz de bytes especificada.

public:
 override int GetBytes(System::String ^ s, int charIndex, int charCount, cli::array <System::Byte> ^ bytes, int byteIndex);
public override int GetBytes(string s, int charIndex, int charCount, byte[] bytes, int byteIndex);
[System.Runtime.InteropServices.ComVisible(false)]
public override int GetBytes(string s, int charIndex, int charCount, byte[] bytes, int byteIndex);
override this.GetBytes : string * int * int * byte[] * int -> int
[<System.Runtime.InteropServices.ComVisible(false)>]
override this.GetBytes : string * int * int * byte[] * int -> int
Public Overrides Function GetBytes (s As String, charIndex As Integer, charCount As Integer, bytes As Byte(), byteIndex As Integer) As Integer

Parâmetros

s
String

O String conjunto de caracteres a ser codificado.

charIndex
Int32

O índice do primeiro caractere a ser codificado.

charCount
Int32

O número de caracteres a serem codificados.

bytes
Byte[]

A matriz de bytes para conter a sequência resultante de bytes.

byteIndex
Int32

O índice no qual começar a gravar a sequência resultante de bytes.

Retornos

O número real de bytes gravados em bytes.

Atributos

Exceções

s é null (Nothing).

-ou-

bytes é null (Nothing).

charIndex ou charCount ou byteIndex é menor que zero.

-ou-

charIndex e charCount não denotar um intervalo válido em s.

-ou-

byteIndex não é um índice válido em bytes.

bytes não tem capacidade suficiente do byteIndex final da matriz para acomodar os bytes resultantes.

Ocorreu um fallback (consulte Codificação doCharacter em .NET para obter uma explicação mais completa).

-e-

EncoderFallback é definido como EncoderExceptionFallback.

Exemplos

O exemplo de código a seguir demonstra como usar o GetBytes método para codificar um intervalo de elementos de uma matriz de caracteres Unicode e armazenar os bytes codificados em um intervalo de elementos em uma matriz de bytes.

using System;
using System.Text;

class UTF7EncodingExample {
    public static void Main() {
        Byte[] bytes;
        // Unicode characters.
        Char[] chars = new Char[] {
            '\u0023', // #
            '\u0025', // %
            '\u03a0', // Pi
            '\u03a3'  // Sigma
        };
        
        UTF7Encoding utf7 = new UTF7Encoding();
        
        int byteCount = utf7.GetByteCount(chars, 1, 2);
        bytes = new Byte[byteCount];
        int bytesEncodedCount = utf7.GetBytes(chars, 1, 2, bytes, 0);
        
        Console.WriteLine(
            "{0} bytes used to encode characters.", bytesEncodedCount
        );

        Console.Write("Encoded bytes: ");
        foreach (Byte b in bytes) {
            Console.Write("[{0}]", b);
        }
        Console.WriteLine();
    }
}
Imports System.Text
Imports Microsoft.VisualBasic.strings

Class UTF7EncodingExample
    
    Public Shared Sub Main()
        Dim bytes() As Byte
        ' Unicode characters.
        ' ChrW(35)  = #
        ' ChrW(37)  = %
        ' ChrW(928) = Pi
        ' ChrW(931) = Sigma
        Dim chars() As Char = {ChrW(35), ChrW(37), ChrW(928), ChrW(931)}
        
        Dim utf7 As New UTF7Encoding()
        
        Dim byteCount As Integer = utf7.GetByteCount(chars, 1, 2)
        bytes = New Byte(byteCount - 1) {}
        Dim bytesEncodedCount As Integer = utf7.GetBytes(chars, 1, 2, bytes, 0)
        
        Console.WriteLine("{0} bytes used to encode characters.", bytesEncodedCount)
        
        Console.Write("Encoded bytes: ")
        Dim b As Byte
        For Each b In  bytes
            Console.Write("[{0}]", b)
        Next b
        Console.WriteLine()
    End Sub
End Class

Comentários

Para calcular o tamanho exato da matriz exigido para GetBytes armazenar os bytes resultantes GetByteCount, o aplicativo usa . Para calcular o tamanho máximo da matriz, o aplicativo deve usar GetMaxByteCount. O GetByteCount método geralmente permite a alocação de menos memória, enquanto o GetMaxByteCount método geralmente é executado mais rapidamente.

Os dados a serem convertidos, como dados lidos de um fluxo, podem estar disponíveis apenas em blocos sequenciais. Nesse caso, ou se a quantidade de dados é tão grande que precisa ser dividida em blocos menores, o aplicativo deve usar o Decoder método ou o Encoder fornecido pelo GetDecoder método ou pelo GetEncoder método, respectivamente.

Note

UTF7Encoding não fornece detecção de erros. Caracteres inválidos são codificados como um caractere base 64 modificado. Por motivos de segurança, recomendamos que seus aplicativos usem UTF8EncodingUnicodeEncodingou UTF32Encoding habilitem a detecção de erros.

Confira também

Aplica-se a