UTF7Encoding.GetBytes Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Codifica um conjunto de caracteres em uma sequência de bytes.
Sobrecargas
GetBytes(Char*, Int32, Byte*, Int32) |
Codifica um conjunto de caracteres começando no ponteiro de caractere especificado em uma sequência de bytes armazenados começando no ponteiro de byte 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 String especificado para a matriz de bytes especificada. |
GetBytes(Char*, Int32, Byte*, Int32)
- Origem:
- UTF7Encoding.cs
- Origem:
- UTF7Encoding.cs
- Origem:
- UTF7Encoding.cs
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 armazenados começando no ponteiro de byte 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)]
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)>]
[<System.Security.SecurityCritical>]
override this.GetBytes : nativeptr<char> * int * nativeptr<byte> * int -> int
[<System.CLSCompliant(false)>]
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
Parâmetros
- chars
- Char*
Um ponteiro para o primeiro caractere a ser codificado.
- charCount
- Int32
O número de caracteres a ser codificado.
- bytes
- Byte*
Um ponteiro para o local no qual a gravação da sequência de bytes resultante deve ser iniciada.
- 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
charCount
ou byteCount
é menor que zero.
byteCount
é menor que o número de bytes resultante.
Ocorreu um fallback (confira Codificação de caracteres no .NET para obter uma explicação mais completa).
-e-
EncoderFallback é definido como EncoderExceptionFallback.
Comentários
Para calcular o tamanho exato da matriz exigido por GetBytes para 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 for tão grande que precisa ser dividida em blocos menores, o aplicativo deverá usar o Decoder ou o Encoder fornecido pelo GetDecoder método ou pelo GetEncoder método , respectivamente.
Observação
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, seus aplicativos são recomendados para usar UTF8Encoding, UnicodeEncodingou UTF32Encoding e habilitar a detecção de erros.
Confira também
Aplica-se a
GetBytes(Char[], Int32, Int32, Byte[], Int32)
- Origem:
- UTF7Encoding.cs
- Origem:
- UTF7Encoding.cs
- Origem:
- UTF7Encoding.cs
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 ser codificado.
- bytes
- Byte[]
A matriz de bytes que conterá a sequência de bytes resultante.
- byteIndex
- Int32
O índice no qual será iniciada a gravação da sequência de bytes resultante.
Retornos
O número real de bytes gravados no bytes
.
Exceções
charIndex
, charCount
ou byteIndex
é menor que zero.
- ou -
charIndex
e charCount
não denotam um intervalo válido em chars
.
- ou -
byteIndex
não é um índice válido em bytes
.
O bytes
não tem capacidade suficiente do byteIndex
ao final da matriz para acomodar os bytes resultantes.
Ocorreu um fallback (confira Codificação de caracteres no .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 namespace System;
using namespace System::Text;
using namespace System::Collections;
int main()
{
array<Byte>^bytes;
// Unicode characters.
// Pi
// Sigma
array<Char>^chars = {L'\u03a0',L'\u03a3',L'\u03a6',L'\u03a9'};
UTF7Encoding^ utf7 = gcnew UTF7Encoding;
int byteCount = utf7->GetByteCount( chars, 1, 2 );
bytes = gcnew array<Byte>(byteCount);
int bytesEncodedCount = utf7->GetBytes( chars, 1, 2, bytes, 0 );
Console::WriteLine( "{0} bytes used to encode characters.", bytesEncodedCount );
Console::Write( "Encoded bytes: " );
IEnumerator^ myEnum = bytes->GetEnumerator();
while ( myEnum->MoveNext() )
{
Byte b = safe_cast<Byte>(myEnum->Current);
Console::Write( "[{0}]", b );
}
Console::WriteLine();
}
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 por GetBytes para 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 for tão grande que precisa ser dividida em blocos menores, o aplicativo deverá usar o Decoder ou o Encoder fornecido pelo GetDecoder método ou pelo GetEncoder método , respectivamente.
Observação
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, seus aplicativos são recomendados para usar UTF8Encoding, UnicodeEncodingou UTF32Encoding e habilitar a detecção de erros.
Confira também
Aplica-se a
GetBytes(String, Int32, Int32, Byte[], Int32)
- Origem:
- UTF7Encoding.cs
- Origem:
- UTF7Encoding.cs
- Origem:
- UTF7Encoding.cs
Codifica um conjunto de caracteres do String especificado para a 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
- charIndex
- Int32
O índice do primeiro caractere a ser codificado.
- charCount
- Int32
O número de caracteres a ser codificado.
- bytes
- Byte[]
A matriz de bytes que conterá a sequência de bytes resultante.
- byteIndex
- Int32
O índice no qual será iniciada a gravação da sequência de bytes resultante.
Retornos
O número real de bytes gravados no bytes
.
- Atributos
Exceções
charIndex
, charCount
ou byteIndex
é menor que zero.
- ou -
charIndex
e charCount
não denotam um intervalo válido em chars
.
- ou -
byteIndex
não é um índice válido em bytes
.
O bytes
não tem capacidade suficiente do byteIndex
ao final da matriz para acomodar os bytes resultantes.
Ocorreu um fallback (confira Codificação de caracteres no .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 namespace System;
using namespace System::Text;
using namespace System::Collections;
int main()
{
array<Byte>^bytes;
// Unicode characters.
// Pi
// Sigma
array<Char>^chars = {L'\u03a0',L'\u03a3',L'\u03a6',L'\u03a9'};
UTF7Encoding^ utf7 = gcnew UTF7Encoding;
int byteCount = utf7->GetByteCount( chars, 1, 2 );
bytes = gcnew array<Byte>(byteCount);
int bytesEncodedCount = utf7->GetBytes( chars, 1, 2, bytes, 0 );
Console::WriteLine( "{0} bytes used to encode characters.", bytesEncodedCount );
Console::Write( "Encoded bytes: " );
IEnumerator^ myEnum = bytes->GetEnumerator();
while ( myEnum->MoveNext() )
{
Byte b = safe_cast<Byte>(myEnum->Current);
Console::Write( "[{0}]", b );
}
Console::WriteLine();
}
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 por GetBytes para 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 for tão grande que precisa ser dividida em blocos menores, o aplicativo deverá usar o Decoder ou o Encoder fornecido pelo GetDecoder método ou pelo GetEncoder método , respectivamente.
Observação
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, seus aplicativos são recomendados para usar UTF8Encoding, UnicodeEncodingou UTF32Encoding e habilitar a detecção de erros.