Sdílet prostřednictvím


UTF8Encoding.GetMaxByteCount(Int32) Metoda

Definice

Vypočítá maximální počet bajtů vytvořených kódováním zadaného počtu znaků.

public:
 override int GetMaxByteCount(int charCount);
public override int GetMaxByteCount (int charCount);
override this.GetMaxByteCount : int -> int
Public Overrides Function GetMaxByteCount (charCount As Integer) As Integer

Parametry

charCount
Int32

Počet znaků, které se mají zakódovat.

Návraty

Maximální počet bajtů vytvořených kódováním zadaného počtu znaků.

Výjimky

Hodnota charCount je menší než nula.

-nebo-

Výsledný počet bajtů je větší než maximální počet, který lze vrátit jako celé číslo.

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

-A-

EncoderFallback je nastavená na EncoderExceptionFallbackhodnotu .

Příklady

Následující příklad používá metodu GetMaxByteCount k vrácení maximálního počtu bajtů potřebných ke kódování zadaného počtu znaků.

using namespace System;
using namespace System::Text;
int main()
{
   UTF8Encoding^ utf8 = gcnew UTF8Encoding;
   int charCount = 2;
   int maxByteCount = utf8->GetMaxByteCount( charCount );
   Console::WriteLine( "Maximum of {0} bytes needed to encode {1} characters.", maxByteCount, charCount );
}
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
        );
    }
}
Imports System.Text

Class UTF8EncodingExample
    
    Public Shared Sub Main()
        Dim utf8 As New UTF8Encoding()
        Dim charCount As Integer = 2
        Dim maxByteCount As Integer = utf8.GetMaxByteCount(charCount)
        Console.WriteLine( _
            "Maximum of {0} bytes needed to encode {1} characters.", _
            maxByteCount, _
            charCount _
        )
    End Sub
End Class

Poznámky

Pokud chcete vypočítat přesnou velikost pole vyžadovanou GetBytes pro uložení výsledných bajtů, zavoláte metodu GetByteCount . Pokud chcete vypočítat maximální velikost pole, zavolejte metodu GetMaxByteCount . Metoda GetByteCount obecně přiděluje méně paměti, zatímco GetMaxByteCount metoda obecně provádí rychleji.

GetMaxByteCount je číslo nejhoršího případu, včetně nejhoršího případu pro aktuálně vybraný EncoderFallback. Pokud zvolíte záložní s potenciálně velkým řetězcem, GetMaxByteCount může vrátit velké hodnoty.

Ve většině případů tato metoda vrátí rozumné hodnoty pro malé řetězce. U velkých řetězců si možná budete muset vybrat mezi použitím velmi velkých vyrovnávacích pamětí a zachycením chyb ve výjimečných případech, kdy dojde k překročení rozumnější vyrovnávací paměti. Můžete také zvážit jiný přístup pomocí nebo GetByteCountEncoder.Convert. Například text v angličtině a mnoha dalších jazycích často potřebuje k reprezentaci znaku pouze jeden bajt UTF-8, ale číslo vrácené uživatelem GetMaxByteCount musí umožňovat možnost, že řetězec, který se má převést, se bude skládat výhradně ze znaků, z nichž každý vyžaduje čtyři bajty.

GetMaxByteCount nemá žádný vztah k GetChars. Pokud vaše aplikace potřebuje podobnou funkci pro použití s GetChars, měla by použít GetMaxCharCount.

Poznámka

GetMaxByteCount(N) není nutně stejná hodnota jako N* GetMaxByteCount(1).

Platí pro

Viz také