ASCIIEncoding.GetChars Метод

Определение

Декодирует последовательность байтов в набор символов.Decodes a sequence of bytes into a set of characters.

Перегрузки

GetChars(ReadOnlySpan<Byte>, Span<Char>)

Декодирует заданный диапазон байтов в заданный диапазон символов.Decodes the specified byte span into the specified character span.

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

Декодирует последовательность байтов, начало которой задается указателем байта, в набор символов, которые сохраняются начиная с заданного указателя символа.Decodes a sequence of bytes starting at the specified byte pointer into a set of characters that are stored starting at the specified character pointer.

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

Декодирует последовательность байтов из заданного массива байтов в указанный массив символов.Decodes a sequence of bytes from the specified byte array into the specified character array.

GetChars(ReadOnlySpan<Byte>, Span<Char>)

Декодирует заданный диапазон байтов в заданный диапазон символов.Decodes the specified byte span into the specified character span.

public:
 override int GetChars(ReadOnlySpan<System::Byte> bytes, Span<char> chars);
public override int GetChars (ReadOnlySpan<byte> bytes, Span<char> chars);
override this.GetChars : ReadOnlySpan<byte> * Span<char> -> int
Public Overrides Function GetChars (bytes As ReadOnlySpan(Of Byte), chars As Span(Of Char)) As Integer

Параметры

bytes
ReadOnlySpan<Byte>

Диапазон, содержащий байты для декодирования.The span containing the bytes to decode.

chars
Span<Char>

Диапазон, содержащий результирующий набор символов.The span to contain the resulting set of characters.

Возвраты

Фактическое число символов, записанных в chars.The actual number of characters written into chars.

Комментарии

Чтобы вычислить точный размер, требуемый GetChars для хранения полученных символов, используйте GetCharCount.To calculate the exact size required by GetChars to store the resulting characters, use GetCharCount. Чтобы вычислить максимальный размер, используйте GetMaxCharCount.To calculate the maximum size, use GetMaxCharCount. Метод GetCharCount обычно позволяет выделить меньше памяти, а метод GetMaxCharCount обычно выполняется быстрее.The GetCharCount method generally allows allocation of less memory, while the GetMaxCharCount method generally executes faster.

Данные для преобразования, например данные, считываемые из потока, могут быть доступны только в последовательных блоках.Data to be converted, such as data read from a stream, can be available only in sequential blocks. В этом случае, или если объем данных настолько велик, что необходимо разделить на меньшие блоки, следует использовать Decoder или Encoder, предоставляемые методом GetDecoder или методом GetEncoder соответственно.In this case, or if the amount of data is so large that it needs to be divided into smaller blocks, you should use the Decoder or the Encoder provided by the GetDecoder method or the GetEncoder method, respectively.

ASCIIEncoding не поддерживает обнаружение ошибок.ASCIIEncoding does not provide error detection. Любой байт больше шестнадцатеричного 0x7F декодирован как вопросительный знак Юникода ("?").Any byte greater than hexadecimal 0x7F is decoded as the Unicode question mark ("?").

Внимание!

В целях безопасности следует использовать UTF8Encoding, UnicodeEncodingили UTF32Encoding и включить обнаружение ошибок.For security reasons, you should use UTF8Encoding, UnicodeEncoding, or UTF32Encoding and enable error detection.

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

Важно!

Этот API несовместим с CLS.

Альтернативный вариант, совместимый с CLS
System.Text.ASCIIEncoding.GetChars(Byte[], Int32, Int32, Char[], Int32)

Декодирует последовательность байтов, начало которой задается указателем байта, в набор символов, которые сохраняются начиная с заданного указателя символа.Decodes a sequence of bytes starting at the specified byte pointer into a set of characters that are stored starting at the specified character pointer.

public:
 override int GetChars(System::Byte* bytes, int byteCount, char* chars, int charCount);
[System.CLSCompliant(false)]
[System.Runtime.InteropServices.ComVisible(false)]
[System.Security.SecurityCritical]
public override int GetChars (byte* bytes, int byteCount, char* chars, int charCount);
override this.GetChars : nativeptr<byte> * int * nativeptr<char> * int -> int

Параметры

bytes
Byte*

Указатель на первый декодируемый байт.A pointer to the first byte to decode.

byteCount
Int32

Число байтов для декодирования.The number of bytes to decode.

chars
Char*

Указатель на положение, с которого начинается запись результирующего набора символов.A pointer to the location at which to start writing the resulting set of characters.

charCount
Int32

Наибольшее количество символов для записи.The maximum number of characters to write.

Возвраты

Фактическое число символов, записанных в местоположение, указанное с помощью параметра chars.The actual number of characters written at the location indicated by chars.

Атрибуты

Исключения

Свойство bytes имеет значение null.bytes is null.

- или --or- Свойство chars имеет значение null.chars is null.

Значение параметра byteCount или charCount меньше нуля.byteCount or charCount is less than zero.

charCount меньше результирующего числа символов.charCount is less than the resulting number of characters.

Произошел откат (см. сведения о кодировке символов в .NET)A fallback occurred (for more information, see Character Encoding in .NET) - и --and- Параметру DecoderFallback задается значение DecoderExceptionFallback.DecoderFallback is set to DecoderExceptionFallback.

Комментарии

Чтобы вычислить точный размер массива, необходимый GetChars для хранения полученных символов, приложение использует GetCharCount.To calculate the exact array size required by GetChars to store the resulting characters, the application uses GetCharCount. Чтобы вычислить максимальный размер массива, приложение должно использовать GetMaxCharCount.To calculate the maximum array size, the application should use GetMaxCharCount. Метод GetCharCount обычно позволяет выделить меньше памяти, а метод GetMaxCharCount обычно выполняется быстрее.The GetCharCount method generally allows allocation of less memory, while the GetMaxCharCount method generally executes faster.

Данные для преобразования, например данные, считываемые из потока, могут быть доступны только в последовательных блоках.Data to be converted, such as data read from a stream, can be available only in sequential blocks. В этом случае, или если объем данных настолько велик, что необходимо разделить на меньшие блоки, приложение должно использовать Decoder или Encoder, предоставляемые методом GetDecoder или методом GetEncoder соответственно.In this case, or if the amount of data is so large that it needs to be divided into smaller blocks, the application should use the Decoder or the Encoder provided by the GetDecoder method or the GetEncoder method, respectively.

ASCIIEncoding не поддерживает обнаружение ошибок.ASCIIEncoding does not provide error detection. Любой байт больше, чем шестнадцатеричное 0x7F, декодирован как вопросительный знак Юникода ("?").Any byte greater than hexadecimal 0x7F is decoded as the Unicode question mark ("?").

Внимание!

В целях безопасности приложение рекомендуется использовать UTF8Encoding, UnicodeEncodingили UTF32Encoding и включить обнаружение ошибок.For security reasons, your application is recommended to use UTF8Encoding, UnicodeEncoding, or UTF32Encoding and enable error detection.

Безопасность

SecurityCriticalAttribute
Требуется полное доверие для немедленного вызывающего объекта.Requires full trust for the immediate caller. Этот член не может использоваться частично доверенным или прозрачным кодом.This member cannot be used by partially trusted or transparent code.

Дополнительно

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

Декодирует последовательность байтов из заданного массива байтов в указанный массив символов.Decodes a sequence of bytes from the specified byte array into the specified character array.

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

Параметры

bytes
Byte[]

Массив байтов, содержащий последовательность байтов, которую требуется декодировать.The byte array containing the sequence of bytes to decode.

byteIndex
Int32

Индекс первого декодируемого байта.The index of the first byte to decode.

byteCount
Int32

Число байтов для декодирования.The number of bytes to decode.

chars
Char[]

Массив символов, в который будет помещен результирующий набор символов.The character array to contain the resulting set of characters.

charIndex
Int32

Индекс, с которого начинается запись результирующего набора символов.The index at which to start writing the resulting set of characters.

Возвраты

Фактическое число символов, записанных в chars.The actual number of characters written into chars.

Исключения

Свойство bytes имеет значение null.bytes is null.

- или --or- charsnull.chars is null.

Значение параметра byteIndex, byteCount или charIndex меньше нуля.byteIndex or byteCount or charIndex is less than zero.

- или --or- Параметрыbyteindex и byteCount не указывают допустимый диапазон в bytes.byteindex and byteCount do not denote a valid range in bytes.

- или --or- Значение параметра charIndex не является допустимым индексом в chars.charIndex is not a valid index in chars.

Недостаточно емкости chars от charIndex до конца массива для размещения полученных символов.chars does not have enough capacity from charIndex to the end of the array to accommodate the resulting characters.

Произошел откат (см. сведения о кодировке символов в .NET)A fallback occurred (for more information, see Character Encoding in .NET) - и --and- Параметру DecoderFallback задается значение DecoderExceptionFallback.DecoderFallback is set to DecoderExceptionFallback.

Примеры

В следующем примере показано, как декодировать диапазон элементов из массива байтов и сохранить результат в наборе элементов в массиве символов Юникода.The following example demonstrates how to decode a range of elements from a byte array and store the result in a set of elements in a Unicode character array.

using namespace System;
using namespace System::Text;
using namespace System::Collections;
int main()
{
   array<Char>^chars;
   array<Byte>^bytes = {65,83,67,73,73,32,69,110,99,111,100,105,110,103,32,69,120,97,109,112,108,101};
   ASCIIEncoding^ ascii = gcnew ASCIIEncoding;
   int charCount = ascii->GetCharCount( bytes, 6, 8 );
   chars = gcnew array<Char>(charCount);
   int charsDecodedCount = ascii->GetChars( bytes, 6, 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 ASCIIEncodingExample {
    public static void Main() {
        Char[] chars;
        Byte[] bytes = new Byte[] {
             65,  83,  67,  73,  73,  32,  69,
            110,  99, 111, 100, 105, 110, 103,
             32,  69, 120,  97, 109, 112, 108, 101
        };

        ASCIIEncoding ascii = new ASCIIEncoding();

        int charCount = ascii.GetCharCount(bytes, 6, 8);
        chars = new Char[charCount];
        int charsDecodedCount = ascii.GetChars(bytes, 6, 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 ASCIIEncodingExample
    Public Shared Sub Main()
        Dim chars() As Char
        Dim bytes() As Byte = { _
             65,  83,  67,  73,  73,  32,  69, _
            110,  99, 111, 100, 105, 110, 103, _
             32,  69, 120,  97, 109, 112, 108, 101}

        Dim ascii As New ASCIIEncoding()

        Dim charCount As Integer = ascii.GetCharCount(bytes, 6, 8)
        chars = New Char(charCount - 1) {}
        Dim charsDecodedCount As Integer = ascii.GetChars(bytes, 6, 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

Комментарии

Чтобы вычислить точный размер массива, необходимый GetChars для хранения полученных символов, приложение использует GetCharCount.To calculate the exact array size required by GetChars to store the resulting characters, the application uses GetCharCount. Чтобы вычислить максимальный размер массива, приложение должно использовать GetMaxCharCount.To calculate the maximum array size, the application should use GetMaxCharCount. Метод GetCharCount обычно позволяет выделить меньше памяти, а метод GetMaxCharCount обычно выполняется быстрее.The GetCharCount method generally allows allocation of less memory, while the GetMaxCharCount method generally executes faster.

Данные для преобразования, например данные, считываемые из потока, могут быть доступны только в последовательных блоках.Data to be converted, such as data read from a stream, can be available only in sequential blocks. В этом случае, или если объем данных настолько велик, что необходимо разделить на меньшие блоки, приложение должно использовать Decoder или Encoder, предоставляемые методом GetDecoder или методом GetEncoder соответственно.In this case, or if the amount of data is so large that it needs to be divided into smaller blocks, the application should use the Decoder or the Encoder provided by the GetDecoder method or the GetEncoder method, respectively.

ASCIIEncoding не поддерживает обнаружение ошибок.ASCIIEncoding does not provide error detection. Любой байт больше, чем шестнадцатеричное 0x7F, декодирован как вопросительный знак Юникода ("?").Any byte greater than hexadecimal 0x7F is decoded as the Unicode question mark ("?").

Внимание!

В целях безопасности приложение рекомендуется использовать UTF8Encoding, UnicodeEncodingили UTF32Encoding и включить обнаружение ошибок.For security reasons, your application is recommended to use UTF8Encoding, UnicodeEncoding, or UTF32Encoding and enable error detection.

Дополнительно

Применяется к