UTF7Encoding.GetBytes Método

Definición

Codifica un conjunto de caracteres en una secuencia de bytes.

Sobrecargas

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

Codifica un conjunto de caracteres a partir del puntero de caracteres especificado en una secuencia de bytes que se almacenan a partir del puntero de bytes especificado.

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

Codifica un conjunto de caracteres de la matriz de caracteres especificada en la matriz de bytes especificada.

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

Codifica un conjunto de caracteres del especificado String en la matriz de bytes especificada.

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

Importante

Esta API no es conforme a CLS.

Codifica un conjunto de caracteres a partir del puntero de caracteres especificado en una secuencia de bytes que se almacenan a partir del puntero 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*

Puntero al primer carácter que se va a codificar.

charCount
Int32

Número de caracteres que se van a codificar.

bytes
Byte*

Puntero a la ubicación en la que se empieza a escribir la secuencia de bytes resultante.

byteCount
Int32

Número máximo de bytes que se van a escribir.

Devoluciones

Número real de bytes escritos en la ubicación indicada por bytes.

Atributos

Excepciones

chars es null (Nothing).

O bien

bytes es null (Nothing).

charCount o byteCount es menor que cero.

byteCount es menor que el número resultante de bytes.

Se produjo una reserva (consulte Codificación decharacter en .NET para obtener una explicación más completa).

- y -

El valor de EncoderFallback está establecido en EncoderExceptionFallback.

Comentarios

Para calcular el tamaño exacto de la matriz requerido por GetBytes para almacenar los bytes resultantes, la aplicación usa GetByteCount. Para calcular el tamaño máximo de la matriz, la aplicación debe usar GetMaxByteCount. El GetByteCount método generalmente permite la asignación de menos memoria, mientras que el GetMaxByteCount método generalmente se ejecuta más rápido.

Los datos que se van a convertir, como los datos leídos de una secuencia, pueden estar disponibles solo en bloques secuenciales. En este caso, o si la cantidad de datos es tan grande que debe dividirse en bloques más pequeños, la aplicación debe usar o Decoder el Encoder proporcionado por el GetDecoder método o el GetEncoder método, respectivamente.

Note

UTF7Encoding no proporciona detección de errores. Los caracteres no válidos se codifican como un carácter de base 64 modificado. Por motivos de seguridad, se recomienda que las aplicaciones usen UTF8Encoding, UnicodeEncodingo UTF32Encoding y habiliten la detección de errores.

Consulte también

Se aplica a

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

Codifica un conjunto de caracteres de la matriz de caracteres especificada en la 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[]

Matriz de caracteres que contiene el conjunto de caracteres que se va a codificar.

charIndex
Int32

Índice del primer carácter que se va a codificar.

charCount
Int32

Número de caracteres que se van a codificar.

bytes
Byte[]

Matriz de bytes que se va a contener la secuencia de bytes resultante.

byteIndex
Int32

Índice en el que se empieza a escribir la secuencia de bytes resultante.

Devoluciones

Número real de bytes escritos en bytes.

Excepciones

chars es null (Nothing).

O bien

bytes es null (Nothing).

charIndex o es charCount menor que byteIndex cero.

O bien

charIndex y charCount no denotan un intervalo válido en chars.

O bien

byteIndex no es un índice válido en bytes.

bytes no tiene suficiente capacidad desde byteIndex hasta el final de la matriz para acomodar los bytes resultantes.

Se produjo una reserva (consulte Codificación decharacter en .NET para obtener una explicación más completa).

- y -

El valor de EncoderFallback está establecido en EncoderExceptionFallback.

Ejemplos

En el ejemplo de código siguiente se muestra cómo usar el GetBytes método para codificar un intervalo de caracteres de y String almacenar los bytes codificados en un intervalo de elementos de una 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

Comentarios

Para calcular el tamaño exacto de la matriz requerido por GetBytes para almacenar los bytes resultantes, la aplicación usa GetByteCount. Para calcular el tamaño máximo de la matriz, la aplicación debe usar GetMaxByteCount. El GetByteCount método generalmente permite la asignación de menos memoria, mientras que el GetMaxByteCount método generalmente se ejecuta más rápido.

Los datos que se van a convertir, como los datos leídos de una secuencia, pueden estar disponibles solo en bloques secuenciales. En este caso, o si la cantidad de datos es tan grande que debe dividirse en bloques más pequeños, la aplicación debe usar o Decoder el Encoder proporcionado por el GetDecoder método o el GetEncoder método, respectivamente.

Note

UTF7Encoding no proporciona detección de errores. Los caracteres no válidos se codifican como un carácter de base 64 modificado. Por motivos de seguridad, se recomienda que las aplicaciones usen UTF8Encoding, UnicodeEncodingo UTF32Encoding y habiliten la detección de errores.

Consulte también

Se aplica a

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

Codifica un conjunto de caracteres del especificado String en la 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

String que contiene el conjunto de caracteres que se va a codificar.

charIndex
Int32

Índice del primer carácter que se va a codificar.

charCount
Int32

Número de caracteres que se van a codificar.

bytes
Byte[]

Matriz de bytes que se va a contener la secuencia de bytes resultante.

byteIndex
Int32

Índice en el que se empieza a escribir la secuencia de bytes resultante.

Devoluciones

Número real de bytes escritos en bytes.

Atributos

Excepciones

s es null (Nothing).

O bien

bytes es null (Nothing).

charIndex o es charCount menor que byteIndex cero.

O bien

charIndex y charCount no denotan un intervalo válido en s.

O bien

byteIndex no es un índice válido en bytes.

bytes no tiene suficiente capacidad desde byteIndex hasta el final de la matriz para acomodar los bytes resultantes.

Se produjo una reserva (consulte Codificación decharacter en .NET para obtener una explicación más completa).

- y -

El valor de EncoderFallback está establecido en EncoderExceptionFallback.

Ejemplos

En el ejemplo de código siguiente se muestra cómo usar el GetBytes método para codificar un intervalo de elementos de una matriz de caracteres Unicode y almacenar los bytes codificados en un intervalo de elementos de una 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

Comentarios

Para calcular el tamaño exacto de la matriz requerido por GetBytes para almacenar los bytes resultantes, la aplicación usa GetByteCount. Para calcular el tamaño máximo de la matriz, la aplicación debe usar GetMaxByteCount. El GetByteCount método generalmente permite la asignación de menos memoria, mientras que el GetMaxByteCount método generalmente se ejecuta más rápido.

Los datos que se van a convertir, como los datos leídos de una secuencia, pueden estar disponibles solo en bloques secuenciales. En este caso, o si la cantidad de datos es tan grande que debe dividirse en bloques más pequeños, la aplicación debe usar o Decoder el Encoder proporcionado por el GetDecoder método o el GetEncoder método, respectivamente.

Note

UTF7Encoding no proporciona detección de errores. Los caracteres no válidos se codifican como un carácter de base 64 modificado. Por motivos de seguridad, se recomienda que las aplicaciones usen UTF8Encoding, UnicodeEncodingo UTF32Encoding y habiliten la detección de errores.

Consulte también

Se aplica a