UTF8Encoding.GetMaxByteCount(Int32) Метод

Определение

Вычисляет максимальное количество байтов, полученных при кодировании заданного числа символов.

public override int GetMaxByteCount (int charCount);

Параметры

charCount
Int32

Число кодируемых символов.

Возвращаемое значение

Максимальное количество байтов, полученных при кодировании заданного количества символов.

Исключения

Значение параметра charCount меньше нуля.

-или-

Результирующее число байтов больше максимального количества, которое можно вернуть как целочисленное значение.

Произошел откат (см. сведения о кодировке символов в .NET)

- и -

Параметру EncoderFallback задается значение EncoderExceptionFallback.

Примеры

В следующем примере метод используется GetMaxByteCount для возврата максимального количества байтов, необходимых для кодирования указанного числа символов.

using System;
using System.Text;

class UTF8EncodingExample {
    public static void Main() {
        UTF8Encoding utf8 = new UTF8Encoding();
        int charCount = 2;
        int maxByteCount = utf8.GetMaxByteCount(charCount);
        Console.WriteLine(
            "Maximum of {0} bytes needed to encode {1} characters.",
            maxByteCount,
            charCount
        );
    }
}

Комментарии

Чтобы вычислить точный размер массива, необходимый GetBytes для хранения результирующего байта, вызовите GetByteCount метод . Чтобы вычислить максимальный размер массива, вызовите GetMaxByteCount метод . Метод GetByteCount обычно выделяет меньше памяти, в то время как GetMaxByteCount метод обычно выполняется быстрее.

GetMaxByteCount — это наихудшее число, включая наихудший вариант для выбранного EncoderFallbackв данный момент . Если выбран резервный вариант с потенциально большой строкой, GetMaxByteCount может возвращать большие значения.

В большинстве случаев этот метод возвращает разумные числа для небольших строк. Для больших строк может потребоваться выбрать между использованием очень больших буферов и перехватом ошибок в редких случаях, когда превышение более разумного буфера. Также можно рассмотреть другой подход с помощью GetByteCount или Encoder.Convert . Например, тексту на английском и многих других языках часто требуется только один байт UTF-8 для представления символа, но число, возвращаемое параметром GetMaxByteCount , должно допускать возможность того, что преобразуемая строка будет полностью состоять из символов, для каждого из которых требуется четыре байта.

GetMaxByteCountне имеет отношения к GetChars . Если приложению требуется аналогичная функция для использования с GetChars, оно должно использовать GetMaxCharCount.

Примечание

GetMaxByteCount(N)не обязательно то же значение, что и N* GetMaxByteCount(1) .

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

Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

См. также раздел