Sdílet prostřednictvím


UTF7Encoding.GetChars Metoda

Definice

Dekóduje posloupnost bajtů do sady znaků.

Přetížení

GetChars(Byte*, Int32, Char*, Int32)

Dekóduje posloupnost bajtů začínající od zadaného ukazatele bajtů do sady znaků, které jsou uloženy od zadaného znakového ukazatele.

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

Dekóduje posloupnost bajtů ze zadaného pole bajtů do zadaného pole znaků.

GetChars(Byte*, Int32, Char*, Int32)

Zdroj:
UTF7Encoding.cs
Zdroj:
UTF7Encoding.cs
Zdroj:
UTF7Encoding.cs

Důležité

Toto rozhraní API neodpovídá specifikaci CLS.

Dekóduje posloupnost bajtů začínající od zadaného ukazatele bajtů do sady znaků, které jsou uloženy od zadaného znakového ukazatele.

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

Parametry

bytes
Byte*

Ukazatel na první bajt k dekódování.

byteCount
Int32

Počet bajtů k dekódování.

chars
Char*

Ukazatel na umístění, ve kterém chcete začít psát výslednou sadu znaků.

charCount
Int32

Maximální počet znaků, které se mají napsat.

Návraty

Skutečný počet znaků napsaných na místě označeném znakem chars.

Atributy

Výjimky

bytes je null (Nothing).

-nebo-

chars je null (Nothing).

byteCount nebo charCount je menší než nula.

charCount je menší než výsledný počet znaků.

Došlo k náhradnímu použití (další informace najdete v tématu Kódování znaků v .NET)

-A-

DecoderFallback je nastavená na DecoderExceptionFallbackhodnotu .

Poznámky

Pokud chcete vypočítat přesnou velikost pole potřebnou GetChars pro uložení výsledných znaků, použijte GetCharCount. K výpočtu maximální velikosti pole by aplikace měla použít GetMaxCharCount. Metoda GetCharCount obecně umožňuje přidělení menší paměti, zatímco GetMaxCharCount metoda se obecně spouští rychleji.

Data, která se mají převést, například data přečtená z datového proudu, můžou být k dispozici pouze v sekvenčních blocích. V takovém případě nebo pokud je množství dat tak velké, že je potřeba je rozdělit na menší bloky, měla by aplikace použít metodu Decoder nebo Encoder metodu, která je poskytována GetDecoder metodou GetEncoder v uvedeném pořadí.

Poznámka

UTF7Encoding neposkytuje detekci chyb. Když se najdou neplatné bajty, UTF7Encoding obvykle vygeneruje neplatné bajty. Pokud je bajt větší než hexadecimální 0x7F, je hodnota bajtu rozšířena na znak Unicode nula, výsledek je uložen v chars poli a všechny sekvence posunu jsou ukončeny. Pokud je například bajt ke kódování šestnáctkového 0x81, výsledný znak je U+0081. Z bezpečnostních důvodů se doporučuje, aby aplikace používaly UTF8Encoding, UnicodeEncodingnebo UTF32Encoding a povolily detekci chyb.

Viz také

Platí pro

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

Zdroj:
UTF7Encoding.cs
Zdroj:
UTF7Encoding.cs
Zdroj:
UTF7Encoding.cs

Dekóduje posloupnost bajtů ze zadaného pole bajtů do zadaného pole znaků.

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

Parametry

bytes
Byte[]

Pole bajtů obsahující posloupnost bajtů k dekódování.

byteIndex
Int32

Index prvního bajtu k dekódování.

byteCount
Int32

Počet bajtů k dekódování.

chars
Char[]

Pole znaků, které má obsahovat výslednou sadu znaků.

charIndex
Int32

Index, ve kterém chcete začít psát výslednou sadu znaků.

Návraty

Skutečný počet znaků zapsaných do chars.

Výjimky

bytes je null (Nothing).

-nebo-

chars je null (Nothing).

byteIndex nebo byteCountcharIndex je menší než nula.

-nebo-

byteindex a byteCount neoznamují platnou oblast v bytessouboru .

-nebo-

charIndex není platný index v nástroji chars.

chars nemá dostatečnou kapacitu od charIndex do konce pole pro umístění výsledných znaků.

Došlo k náhradnímu použití (další informace najdete v tématu Kódování znaků v .NET)

-A-

DecoderFallback je nastavená na DecoderExceptionFallbackhodnotu .

Příklady

Následující příklad kódu ukazuje, jak použít metodu GetChars k dekódování rozsahu prvků v bajtovém poli a uložit výsledek do pole znaků.

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

Poznámky

Pokud chcete vypočítat přesnou velikost pole potřebnou GetChars pro uložení výsledných znaků, použijte GetCharCount. K výpočtu maximální velikosti pole by aplikace měla použít GetMaxCharCount. Metoda GetCharCount obecně umožňuje přidělení menší paměti, zatímco GetMaxCharCount metoda se obecně spouští rychleji.

Data, která se mají převést, například data přečtená z datového proudu, můžou být k dispozici pouze v sekvenčních blocích. V takovém případě nebo pokud je množství dat tak velké, že je potřeba je rozdělit na menší bloky, měla by aplikace použít metodu Decoder nebo Encoder metodu, která je poskytována GetDecoder metodou GetEncoder v uvedeném pořadí.

Poznámka

UTF7Encoding neposkytuje detekci chyb. Když se najdou neplatné bajty, UTF7Encoding obvykle vygeneruje neplatné bajty. Pokud je bajt větší než hexadecimální 0x7F, je hodnota bajtu rozšířena na znak Unicode nula, výsledek je uložen v chars poli a všechny sekvence posunu jsou ukončeny. Pokud je například bajt ke kódování šestnáctkového 0x81, výsledný znak je U+0081. Z bezpečnostních důvodů se doporučuje, aby aplikace používaly UTF8Encoding, UnicodeEncodingnebo UTF32Encoding a povolily detekci chyb.

Viz také

Platí pro