UTF7Encoding.GetChars Metodo
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Decodifica una sequenza di byte in un set di caratteri.
Overload
GetChars(Byte*, Int32, Char*, Int32) |
Decodifica una sequenza di byte a partire dal puntatore ai byte specificato in un set di caratteri archiviati a partire dal puntatore ai caratteri specificato. |
GetChars(Byte[], Int32, Int32, Char[], Int32) |
Decodifica una sequenza di byte dalla matrice di byte specificata nella matrice di caratteri specificata. |
GetChars(Byte*, Int32, Char*, Int32)
- Origine:
- UTF7Encoding.cs
- Origine:
- UTF7Encoding.cs
- Origine:
- UTF7Encoding.cs
Importante
Questa API non è conforme a CLS.
Decodifica una sequenza di byte a partire dal puntatore ai byte specificato in un set di caratteri archiviati a partire dal puntatore ai caratteri specificato.
public:
override int GetChars(System::Byte* bytes, int byteCount, char* chars, int charCount);
[System.CLSCompliant(false)]
[System.Security.SecurityCritical]
public override int GetChars (byte* bytes, int byteCount, char* chars, int charCount);
[System.CLSCompliant(false)]
public override int GetChars (byte* bytes, int byteCount, char* chars, int charCount);
[System.CLSCompliant(false)]
[System.Runtime.InteropServices.ComVisible(false)]
public override int GetChars (byte* bytes, int byteCount, char* chars, int charCount);
[System.CLSCompliant(false)]
[System.Security.SecurityCritical]
[System.Runtime.InteropServices.ComVisible(false)]
public override int GetChars (byte* bytes, int byteCount, char* chars, int charCount);
[<System.CLSCompliant(false)>]
[<System.Security.SecurityCritical>]
override this.GetChars : nativeptr<byte> * int * nativeptr<char> * int -> int
[<System.CLSCompliant(false)>]
override this.GetChars : nativeptr<byte> * int * nativeptr<char> * int -> int
[<System.CLSCompliant(false)>]
[<System.Runtime.InteropServices.ComVisible(false)>]
override this.GetChars : nativeptr<byte> * int * nativeptr<char> * int -> int
[<System.CLSCompliant(false)>]
[<System.Security.SecurityCritical>]
[<System.Runtime.InteropServices.ComVisible(false)>]
override this.GetChars : nativeptr<byte> * int * nativeptr<char> * int -> int
Parametri
- bytes
- Byte*
Puntatore al primo byte da decodificare.
- byteCount
- Int32
Numero di byte da decodificare.
- chars
- Char*
Puntatore alla posizione in cui iniziare a scrivere il set di caratteri risultante.
- charCount
- Int32
Numero massimo di caratteri da scrivere.
Restituisce
Numero effettivo di caratteri scritti nella posizione indicata da chars
.
- Attributi
Eccezioni
byteCount
o charCount
è minore di zero.
charCount
è minore del numero di caratteri risultante.
Si è verificato un fallback (per altre informazioni, vedere Codifica dei caratteri in .NET)
-e-
DecoderFallback è impostato su DecoderExceptionFallback.
Commenti
Per calcolare le dimensioni esatte della matrice richieste da GetChars per archiviare i caratteri risultanti, usare GetCharCount. Per calcolare le dimensioni massime della matrice, l'applicazione deve usare GetMaxCharCount. Il GetCharCount metodo in genere consente l'allocazione di una quantità di memoria inferiore, mentre il GetMaxCharCount metodo viene in genere eseguito più velocemente.
I dati da convertire, ad esempio i dati letti da un flusso, potrebbero essere disponibili solo in blocchi sequenziali. In questo caso, o se la quantità di dati è così grande che deve essere suddivisa in blocchi più piccoli, l'applicazione deve usare DecoderEncoder rispettivamente o il GetDecoder metodo fornito dal metodo o dal GetEncoder metodo.
Nota
UTF7Encoding non fornisce il rilevamento degli errori. Quando vengono rilevati byte non validi, UTF7Encoding in genere genera i byte non validi. Se un byte è maggiore dell'esadecimale 0x7F, il valore di byte viene esteso zero in un carattere Unicode, il risultato viene archiviato nella chars
matrice e qualsiasi sequenza di maiuscole viene terminata. Ad esempio, se il byte da codificare è esadecimale 0x81, il carattere risultante è U+0081. Per motivi di sicurezza, è consigliabile usare UTF8Encoding, UnicodeEncodingo UTF32Encoding e abilitare il rilevamento degli errori.
Vedi anche
- GetCharCount(Byte[], Int32, Int32)
- GetMaxCharCount(Int32)
- GetDecoder()
- GetString(Byte[], Int32, Int32)
Si applica a
GetChars(Byte[], Int32, Int32, Char[], Int32)
- Origine:
- UTF7Encoding.cs
- Origine:
- UTF7Encoding.cs
- Origine:
- UTF7Encoding.cs
Decodifica una sequenza di byte dalla matrice di byte specificata nella matrice di caratteri specificata.
public:
override int GetChars(cli::array <System::Byte> ^ bytes, int byteIndex, int byteCount, cli::array <char> ^ chars, int charIndex);
public override int GetChars (byte[] bytes, int byteIndex, int byteCount, char[] chars, int charIndex);
override this.GetChars : byte[] * int * int * char[] * int -> int
Public Overrides Function GetChars (bytes As Byte(), byteIndex As Integer, byteCount As Integer, chars As Char(), charIndex As Integer) As Integer
Parametri
- bytes
- Byte[]
Matrice di byte contenente la sequenza di byte da decodificare.
- byteIndex
- Int32
Indice del primo byte da decodificare.
- byteCount
- Int32
Numero di byte da decodificare.
- chars
- Char[]
Matrice di caratteri che deve contenere il set di caratteri risultante.
- charIndex
- Int32
Indice in corrispondenza del quale iniziare a scrivere il set di caratteri risultante.
Restituisce
Numero effettivo di caratteri scritti in chars
.
Eccezioni
byteIndex
o byteCount
o charIndex
è minore di zero.
-oppure-
byteindex
e byteCount
non identificano un intervallo valido in bytes
.
-oppure-
charIndex
non è un indice valido in chars
.
chars
non dispone di sufficiente capacità da charIndex
alla fine della matrice per contenere i caratteri risultanti.
Si è verificato un fallback (per altre informazioni, vedere Codifica dei caratteri in .NET)
-e-
DecoderFallback è impostato su DecoderExceptionFallback.
Esempio
Nell'esempio di codice seguente viene illustrato come usare il metodo per decodificare un intervallo di elementi in una matrice di byte e archiviare il GetChars risultato in una matrice di caratteri.
using namespace System;
using namespace System::Text;
using namespace System::Collections;
int main()
{
array<Char>^chars;
array<Byte>^bytes = {85,84,70,55,32,69,110,99,111,100,105,110,103,32,69,120,97,109,112,108,101};
UTF7Encoding^ utf7 = gcnew UTF7Encoding;
int charCount = utf7->GetCharCount( bytes, 2, 8 );
chars = gcnew array<Char>(charCount);
int charsDecodedCount = utf7->GetChars( bytes, 2, 8, 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 UTF7EncodingExample {
public static void Main() {
Char[] chars;
Byte[] bytes = new Byte[] {
85, 84, 70, 55, 32, 69, 110,
99, 111, 100, 105, 110, 103, 32,
69, 120, 97, 109, 112, 108, 101
};
UTF7Encoding utf7 = new UTF7Encoding();
int charCount = utf7.GetCharCount(bytes, 2, 8);
chars = new Char[charCount];
int charsDecodedCount = utf7.GetChars(bytes, 2, 8, 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 UTF7EncodingExample
Public Shared Sub Main()
Dim chars() As Char
Dim bytes() As Byte = { _
85, 84, 70, 55, 32, 69, 110, _
99, 111, 100, 105, 110, 103, 32, _
69, 120, 97, 109, 112, 108, 101 _
}
Dim utf7 As New UTF7Encoding()
Dim charCount As Integer = utf7.GetCharCount(bytes, 2, 8)
chars = New Char(charCount - 1) {}
Dim charsDecodedCount As Integer = utf7.GetChars(bytes, 2, 8, 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
Commenti
Per calcolare le dimensioni esatte della matrice richieste da GetChars per archiviare i caratteri risultanti, usare GetCharCount. Per calcolare le dimensioni massime della matrice, l'applicazione deve usare GetMaxCharCount. Il GetCharCount metodo in genere consente l'allocazione di una quantità di memoria inferiore, mentre il GetMaxCharCount metodo viene in genere eseguito più velocemente.
I dati da convertire, ad esempio i dati letti da un flusso, potrebbero essere disponibili solo in blocchi sequenziali. In questo caso, o se la quantità di dati è così grande che deve essere suddivisa in blocchi più piccoli, l'applicazione deve usare DecoderEncoder rispettivamente o il GetDecoder metodo fornito dal metodo o dal GetEncoder metodo.
Nota
UTF7Encoding non fornisce il rilevamento degli errori. Quando vengono rilevati byte non validi, UTF7Encoding in genere genera i byte non validi. Se un byte è maggiore dell'esadecimale 0x7F, il valore di byte viene esteso zero in un carattere Unicode, il risultato viene archiviato nella chars
matrice e qualsiasi sequenza di maiuscole viene terminata. Ad esempio, se il byte da codificare è esadecimale 0x81, il carattere risultante è U+0081. Per motivi di sicurezza, è consigliabile usare UTF8Encoding, UnicodeEncodingo UTF32Encoding e abilitare il rilevamento degli errori.
Vedi anche
- GetCharCount(Byte[], Int32, Int32)
- GetMaxCharCount(Int32)
- GetDecoder()
- GetString(Byte[], Int32, Int32)