UTF7Encoding.GetBytes Methode

Definition

Codiert eine Reihe von Zeichen in eine Bytesequenz.

Überlädt

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

Codiert eine Reihe von Zeichen, die mit dem angegebenen Zeichenzeiger beginnen, in eine Abfolge von Bytes, die ab dem angegebenen Bytezeiger gespeichert werden.

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

Codiert eine Reihe von Zeichen aus dem angegebenen Zeichenarray in das angegebene Bytearray.

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

Codiert eine Reihe von Zeichen aus dem angegebenen String Bytearray.

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

Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs

Wichtig

Diese API ist nicht CLS-kompatibel.

Codiert eine Reihe von Zeichen, die mit dem angegebenen Zeichenzeiger beginnen, in eine Abfolge von Bytes, die ab dem angegebenen Bytezeiger gespeichert werden.

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

Parameter

chars
Char*

Ein Zeiger auf das erste zeichen, das codiert werden soll.

charCount
Int32

Die Anzahl der zu codierenden Zeichen.

bytes
Byte*

Ein Zeiger auf die Position, an der die resultierende Folge von Bytes geschrieben werden soll.

byteCount
Int32

Die maximale Anzahl von Bytes, die geschrieben werden sollen.

Gibt zurück

Die tatsächliche Anzahl der Bytes, die an der angegebenen Position geschrieben wurden bytes.

Attribute

Ausnahmen

chars ist null (Nothing).

-oder-

bytes ist null (Nothing).

charCount oder byteCount ist kleiner als Null.

byteCount ist kleiner als die resultierende Anzahl von Bytes.

Ein Fallback ist aufgetreten (siehe Character-Codierung in .NET zur vollständigen Erläuterung).

-und-

EncoderFallback ist auf EncoderExceptionFallback festgelegt.

Hinweise

Um die genaue Arraygröße zu berechnen, die zum GetBytes Speichern der resultierenden Bytes erforderlich ist, verwendet GetByteCountdie Anwendung . Um die maximale Arraygröße zu berechnen, sollte die Anwendung verwenden GetMaxByteCount. Die GetByteCount Methode ermöglicht in der Regel die Zuordnung von weniger Arbeitsspeicher, während die GetMaxByteCount Methode im Allgemeinen schneller ausgeführt wird.

Daten, die konvertiert werden sollen, z. B. Daten, die aus einem Datenstrom gelesen werden, sind möglicherweise nur in sequenziellen Blöcken verfügbar. In diesem Fall oder wenn die Datenmenge so groß ist, dass sie in kleinere Blöcke unterteilt werden muss, sollte die Anwendung die Decoder oder die Encoder von der GetDecoder Methode bzw. methode GetEncoder bereitgestellte Verwenden.

Note

UTF7Encoding stellt keine Fehlererkennung bereit. Ungültige Zeichen werden als geändertes Base64-Zeichen codiert. Aus Sicherheitsgründen wird empfohlen, Ihre Anwendungen zu verwenden UTF8Encoding, UnicodeEncodingoder UTF32Encoding die Fehlererkennung zu aktivieren.

Weitere Informationen

Gilt für:

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

Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs

Codiert eine Reihe von Zeichen aus dem angegebenen Zeichenarray in das angegebene Bytearray.

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

Parameter

chars
Char[]

Das Zeichenarray, das die zu codierenden Zeichensätze enthält.

charIndex
Int32

Der Index des ersten zu codierenden Zeichens.

charCount
Int32

Die Anzahl der zu codierenden Zeichen.

bytes
Byte[]

Das Bytearray, das die resultierende Folge von Bytes enthält.

byteIndex
Int32

Der Index, bei dem mit dem Schreiben der resultierenden Bytesequenz begonnen werden soll.

Gibt zurück

Die tatsächliche Anzahl der in bytes.

Ausnahmen

chars ist null (Nothing).

-oder-

bytes ist null (Nothing).

charIndex oder charCountbyteIndex ist kleiner als Null.

-oder-

charIndex und charCount keinen gültigen Bereich in chars.

-oder-

byteIndex ist kein gültiger Index in bytes.

bytes verfügt nicht über genügend Kapazität vom byteIndex Ende des Arrays, um die resultierenden Bytes aufzunehmen.

Ein Fallback ist aufgetreten (siehe Character-Codierung in .NET zur vollständigen Erläuterung).

-und-

EncoderFallback ist auf EncoderExceptionFallback festgelegt.

Beispiele

Im folgenden Codebeispiel wird veranschaulicht, wie die GetBytes Methode verwendet wird, um einen Zeichenbereich aus einem String Zeichenbereich zu codieren und die codierten Bytes in einem Bereich von Elementen in einem Bytearray zu speichern.

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

Hinweise

Um die genaue Arraygröße zu berechnen, die zum GetBytes Speichern der resultierenden Bytes erforderlich ist, verwendet GetByteCountdie Anwendung . Um die maximale Arraygröße zu berechnen, sollte die Anwendung verwenden GetMaxByteCount. Die GetByteCount Methode ermöglicht in der Regel die Zuordnung von weniger Arbeitsspeicher, während die GetMaxByteCount Methode im Allgemeinen schneller ausgeführt wird.

Daten, die konvertiert werden sollen, z. B. Daten, die aus einem Datenstrom gelesen werden, sind möglicherweise nur in sequenziellen Blöcken verfügbar. In diesem Fall oder wenn die Datenmenge so groß ist, dass sie in kleinere Blöcke unterteilt werden muss, sollte die Anwendung die Decoder oder die Encoder von der GetDecoder Methode bzw. methode GetEncoder bereitgestellte Verwenden.

Note

UTF7Encoding stellt keine Fehlererkennung bereit. Ungültige Zeichen werden als geändertes Base64-Zeichen codiert. Aus Sicherheitsgründen wird empfohlen, Ihre Anwendungen zu verwenden UTF8Encoding, UnicodeEncodingoder UTF32Encoding die Fehlererkennung zu aktivieren.

Weitere Informationen

Gilt für:

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

Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs
Quelle:
UTF7Encoding.cs

Codiert eine Reihe von Zeichen aus dem angegebenen String Bytearray.

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

Parameter

s
String

Die String enthaltende Zeichenmenge, die codiert werden soll.

charIndex
Int32

Der Index des ersten zu codierenden Zeichens.

charCount
Int32

Die Anzahl der zu codierenden Zeichen.

bytes
Byte[]

Das Bytearray, das die resultierende Folge von Bytes enthält.

byteIndex
Int32

Der Index, bei dem mit dem Schreiben der resultierenden Bytesequenz begonnen werden soll.

Gibt zurück

Die tatsächliche Anzahl der in bytes.

Attribute

Ausnahmen

s ist null (Nothing).

-oder-

bytes ist null (Nothing).

charIndex oder charCountbyteIndex ist kleiner als Null.

-oder-

charIndex und charCount keinen gültigen Bereich in s.

-oder-

byteIndex ist kein gültiger Index in bytes.

bytes verfügt nicht über genügend Kapazität vom byteIndex Ende des Arrays, um die resultierenden Bytes aufzunehmen.

Ein Fallback ist aufgetreten (siehe Character-Codierung in .NET zur vollständigen Erläuterung).

-und-

EncoderFallback ist auf EncoderExceptionFallback festgelegt.

Beispiele

Im folgenden Codebeispiel wird veranschaulicht, wie Die GetBytes Methode verwendet wird, um einen Bereich von Elementen aus einem Unicode-Zeichenarray zu codieren und die codierten Bytes in einem Bereich von Elementen in einem Bytearray zu speichern.

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

Hinweise

Um die genaue Arraygröße zu berechnen, die zum GetBytes Speichern der resultierenden Bytes erforderlich ist, verwendet GetByteCountdie Anwendung . Um die maximale Arraygröße zu berechnen, sollte die Anwendung verwenden GetMaxByteCount. Die GetByteCount Methode ermöglicht in der Regel die Zuordnung von weniger Arbeitsspeicher, während die GetMaxByteCount Methode im Allgemeinen schneller ausgeführt wird.

Daten, die konvertiert werden sollen, z. B. Daten, die aus einem Datenstrom gelesen werden, sind möglicherweise nur in sequenziellen Blöcken verfügbar. In diesem Fall oder wenn die Datenmenge so groß ist, dass sie in kleinere Blöcke unterteilt werden muss, sollte die Anwendung die Decoder oder die Encoder von der GetDecoder Methode bzw. methode GetEncoder bereitgestellte Verwenden.

Note

UTF7Encoding stellt keine Fehlererkennung bereit. Ungültige Zeichen werden als geändertes Base64-Zeichen codiert. Aus Sicherheitsgründen wird empfohlen, Ihre Anwendungen zu verwenden UTF8Encoding, UnicodeEncodingoder UTF32Encoding die Fehlererkennung zu aktivieren.

Weitere Informationen

Gilt für: