ASCIIEncoding.GetBytes Método
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
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.
- Alternativa conforme a CLS
- System.Text.ASCIIEncoding.GetBytes(Char[], Int32, 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.
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
charCount o byteCount es menor que cero.
byteCount es menor que el número resultante de bytes.
Se produjo una reserva (para obtener más información, vea Codificación de caracteres en .NET).
- 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, solo pueden estar disponibles 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.
ASCIIEncoding no proporciona detección de errores. Cualquier carácter Unicode mayor que U+007F se traduce a un signo de interrogación ASCII ("?").
Caution
Por motivos de seguridad, se recomienda que la aplicación use UTF8Encoding, UnicodeEncodingo UTF32Encoding y habilite 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
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 (para obtener más información, vea Codificación de caracteres en .NET).
- y -
El valor de EncoderFallback está establecido en EncoderExceptionFallback.
Ejemplos
En el ejemplo siguiente se muestra cómo usar el GetBytes método para codificar un intervalo de caracteres de una cadena y almacenar los caracteres codificados en un intervalo de elementos de una matriz de bytes.
using System;
using System.Text;
class ASCIIEncodingExample {
public static void Main() {
Byte[] bytes;
String chars = "ASCII Encoding Example";
ASCIIEncoding ascii = new ASCIIEncoding();
int byteCount = ascii.GetByteCount(chars.ToCharArray(), 6, 8);
bytes = new Byte[byteCount];
int bytesEncodedCount = ascii.GetBytes(chars, 6, 8, bytes, 0);
Console.WriteLine(
"{0} bytes used to encode string.", bytesEncodedCount
);
Console.Write("Encoded bytes: ");
foreach (Byte b in bytes) {
Console.Write("[{0}]", b);
}
Console.WriteLine();
}
}
Imports System.Text
Class ASCIIEncodingExample
Public Shared Sub Main()
Dim bytes() As Byte
Dim chars As String = "ASCII Encoding Example"
Dim ascii As New ASCIIEncoding()
Dim byteCount As Integer = ascii.GetByteCount(chars.ToCharArray(), 6, 8)
bytes = New Byte(byteCount - 1) {}
Dim bytesEncodedCount As Integer = ascii.GetBytes(chars, 6, 8, bytes, 0)
Console.WriteLine("{0} bytes used to encode string.", 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, solo pueden estar disponibles 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.
ASCIIEncoding no proporciona detección de errores. Cualquier carácter Unicode mayor que U+007F se codifica como el signo de interrogación ASCII ("?").
Caution
Por motivos de seguridad, se recomienda que la aplicación use UTF8Encoding, UnicodeEncodingo UTF32Encoding y habilite 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 ^ chars, int charIndex, int charCount, cli::array <System::Byte> ^ bytes, int byteIndex);
public override int GetBytes(string chars, int charIndex, int charCount, byte[] bytes, int byteIndex);
override this.GetBytes : string * int * int * byte[] * int -> int
Public Overrides Function GetBytes (chars As String, charIndex As Integer, charCount As Integer, bytes As Byte(), byteIndex As Integer) As Integer
Parámetros
- chars
- String
Conjunto de caracteres que se van 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 o bytes es null.
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 (para obtener más información, vea Codificación de caracteres en .NET).
- y -
El valor de EncoderFallback está establecido en EncoderExceptionFallback.
Ejemplos
En el ejemplo 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 ASCIIEncodingExample {
public static void Main() {
Byte[] bytes;
// Unicode characters.
Char[] chars = new Char[] {
'\u0023', // #
'\u0025', // %
'\u03a0', // Pi
'\u03a3' // Sigma
};
ASCIIEncoding ascii = new ASCIIEncoding();
int byteCount = ascii.GetByteCount(chars, 1, 2);
bytes = new Byte[byteCount];
int bytesEncodedCount = ascii.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 ASCIIEncodingExample
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 ascii As New ASCIIEncoding()
Dim byteCount As Integer = ascii.GetByteCount(chars, 1, 2)
bytes = New Byte(byteCount - 1){}
Dim bytesEncodedCount As Integer = ascii.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, solo pueden estar disponibles 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.
ASCIIEncoding no proporciona detección de errores. Cualquier carácter Unicode mayor que U+007F se codifica como el signo de interrogación ASCII ("?").
Caution
Por motivos de seguridad, se recomienda usar UTF8Encoding, UnicodeEncodingo UTF32Encoding y habilitar la detección de errores.