ASCIIEncoding.GetBytes Metódus

Definíció

Egy karakterkészletet bájtok sorozatába kódol.

Túlterhelések

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

A megadott karaktermutatótól kezdődő karakterkészletet bájtok sorozatába kódolja, amelyek a megadott bájtmutatótól kezdve vannak tárolva.

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

Egy karakterkészletet kódol a megadott karaktertömbből a megadott bájttömbbe.

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

A megadott String bájttömbbe kódol egy karakterkészletet.

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

Fontos

Ez az API nem CLS-kompatibilis.

CLS-kompatibilis alternatíva
System.Text.ASCIIEncoding.GetBytes(Char[], Int32, Int32, Byte[], Int32)

A megadott karaktermutatótól kezdődő karakterkészletet bájtok sorozatába kódolja, amelyek a megadott bájtmutatótól kezdve vannak tárolva.

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

Paraméterek

chars
Char*

A kódolni kívánt első karakterre mutató mutató.

charCount
Int32

A kódolandó karakterek száma.

bytes
Byte*

Egy mutató arra a helyre, ahol elkezdi írni az eredményként kapott bájtsorozatot.

byteCount
Int32

Az írható bájtok maximális száma.

Válaszok

A megadott helyen bytesírt bájtok tényleges száma.

Attribútumok

Kivételek

chars az null.

-vagy-

bytes az null.

charCount vagy byteCount kisebb, mint nulla.

byteCount kisebb, mint az eredményként kapott bájtok száma.

Hiba történt (további információ: Acharacter kódolása a .NET)

-és-

EncoderFallback EncoderExceptionFallbackértékre van állítva.

Megjegyzések

A kapott bájtok tárolásához szükséges GetBytes pontos tömbméret kiszámításához az alkalmazás a következőt használja GetByteCount: . A maximális tömbméret kiszámításához az alkalmazásnak a következőt kell használnia GetMaxByteCount: . A GetByteCount metódus általában kevesebb memória lefoglalását teszi lehetővé, míg a GetMaxByteCount metódus általában gyorsabban fut.

Az átalakítandó adatok, például a streamből beolvasott adatok csak szekvenciális blokkokban érhetők el. Ebben az esetben, vagy ha az adatok mennyisége olyan nagy, hogy kisebb blokkokra kell osztani, az alkalmazásnak a Decoder metódus vagy Encoder a GetEncoder metódus által GetDecoder megadott vagy megadott adatokat kell használnia.

ASCIIEncoding nem biztosít hibaészlelést. Az U+007F-nél nagyobb Unicode-karakterek ascii kérdőjelre ("?") lesznek lefordítva.

Figyelmeztetés

Biztonsági okokból javasoljuk, hogy az alkalmazást használja UTF8Encoding, UnicodeEncodingvagy UTF32Encoding engedélyezze a hibaészlelést.

Lásd még

A következőre érvényes:

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

Egy karakterkészletet kódol a megadott karaktertömbből a megadott bájttömbbe.

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

Paraméterek

chars
Char[]

A kódolandó karaktereket tartalmazó karaktertömb.

charIndex
Int32

Az első kódolandó karakter indexe.

charCount
Int32

A kódolandó karakterek száma.

bytes
Byte[]

Az eredményként kapott bájtsorozatot tartalmazó bájttömb.

byteIndex
Int32

Az az index, amelynél elkezdi írni az eredményként kapott bájtsorozatot.

Válaszok

A beírt bytesbájtok tényleges száma.

Kivételek

chars az null.

-vagy-

bytes az null.

charIndex vagy charCountbyteIndex kisebb, mint nulla.

-vagy-

charIndex és charCount ne jelölje az érvényes tartományt a következőben chars: .

-vagy-

byteIndex érvénytelen index a következőben bytes: .

bytes nem rendelkezik elegendő kapacitással a tömb végétől byteIndex a kapott bájtok elhelyezéséhez.

Hiba történt (további információ: Acharacter kódolása a .NET)

-és-

EncoderFallback EncoderExceptionFallbackértékre van állítva.

Példák

Az alábbi példa bemutatja, hogyan kódolhat egy karakterláncból származó karaktertartományt a metódussal GetBytes , és hogyan tárolhatja a kódolt karaktereket egy bájttömb elemeinek tartományában.

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

Megjegyzések

A kapott bájtok tárolásához szükséges GetBytes pontos tömbméret kiszámításához az alkalmazás a következőt használja GetByteCount: . A maximális tömbméret kiszámításához az alkalmazásnak a következőt kell használnia GetMaxByteCount: . A GetByteCount metódus általában kevesebb memória lefoglalását teszi lehetővé, míg a GetMaxByteCount metódus általában gyorsabban fut.

Az átalakítandó adatok, például a streamből beolvasott adatok csak szekvenciális blokkokban érhetők el. Ebben az esetben, vagy ha az adatok mennyisége olyan nagy, hogy kisebb blokkokra kell osztani, az alkalmazásnak a Decoder metódus vagy Encoder a GetEncoder metódus által GetDecoder megadott vagy megadott adatokat kell használnia.

ASCIIEncoding nem biztosít hibaészlelést. Az U+007F-nél nagyobb Unicode-karakterek ASCII kérdőjelként ("?") vannak kódolva.

Figyelmeztetés

Biztonsági okokból javasoljuk, hogy az alkalmazást használja UTF8Encoding, UnicodeEncodingvagy UTF32Encoding engedélyezze a hibaészlelést.

Lásd még

A következőre érvényes:

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

A megadott String bájttömbbe kódol egy karakterkészletet.

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

Paraméterek

chars
String

A kódolandó karakterek készlete.

charIndex
Int32

Az első kódolandó karakter indexe.

charCount
Int32

A kódolandó karakterek száma.

bytes
Byte[]

Az eredményként kapott bájtsorozatot tartalmazó bájttömb.

byteIndex
Int32

Az az index, amelynél elkezdi írni az eredményként kapott bájtsorozatot.

Válaszok

A beírt bytesbájtok tényleges száma.

Kivételek

chars vagy bytes az null.

charIndex vagy charCountbyteIndex kisebb, mint nulla.

-vagy-

charIndex és charCount ne jelölje az érvényes tartományt a következőben chars: .

-vagy-

byteIndex érvénytelen index a következőben bytes: .

bytes nem rendelkezik elegendő kapacitással a tömb végétől byteIndex a kapott bájtok elhelyezéséhez.

Hiba történt (további információ: Acharacter kódolása a .NET)

-és-

EncoderFallback EncoderExceptionFallbackértékre van állítva.

Példák

Az alábbi példa bemutatja, hogyan kódolhat GetBytes egy Unicode-karaktertömb elemeinek tartományát, és hogyan tárolhatja a kódolt bájtokat egy bájttömb elemeinek egy tartományában.

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

Megjegyzések

A kapott bájtok tárolásához szükséges GetBytes pontos tömbméret kiszámításához az alkalmazás a következőt használja GetByteCount: . A maximális tömbméret kiszámításához az alkalmazásnak a következőt kell használnia GetMaxByteCount: . A GetByteCount metódus általában kevesebb memória lefoglalását teszi lehetővé, míg a GetMaxByteCount metódus általában gyorsabban fut.

Az átalakítandó adatok, például a streamből beolvasott adatok csak szekvenciális blokkokban érhetők el. Ebben az esetben, vagy ha az adatok mennyisége olyan nagy, hogy kisebb blokkokra kell osztani, az alkalmazásnak a Decoder metódus vagy Encoder a GetEncoder metódus által GetDecoder megadott vagy megadott adatokat kell használnia.

ASCIIEncoding nem biztosít hibaészlelést. Az U+007F-nél nagyobb Unicode-karakterek ASCII kérdőjelként ("?") vannak kódolva.

Figyelmeztetés

Biztonsági okokból javasoljuk a hibaészlelés használatát UTF8EncodingUnicodeEncodingvagy UTF32Encoding engedélyezését.

Lásd még

A következőre érvényes: