UTF7Encoding.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í kódovat.

Návraty

Int32

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 int.

Došlo k náhradnímu obnovení (další informace najdete v tématu Kódování znaků v .NET). -a- EncoderFallback je nastavena na EncoderExceptionFallbackhodnotu .

Příklady

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

using namespace System;
using namespace System::Text;
int main()
{
   UTF7Encoding^ utf7 = gcnew UTF7Encoding;
   int charCount = 2;
   int maxByteCount = utf7->GetMaxByteCount( charCount );
   Console::WriteLine( "Maximum of {0} bytes needed to encode {1} characters.", maxByteCount, charCount );
}
using System;
using System.Text;

class UTF7EncodingExample {
    public static void Main() {
        UTF7Encoding utf7 = new UTF7Encoding();
        int charCount = 2;
        int maxByteCount = utf7.GetMaxByteCount(charCount);
        Console.WriteLine(
            "Maximum of {0} bytes needed to encode {1} characters.",
            maxByteCount,
            charCount
        );
    }
}
Imports System.Text

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

Poznámky

K výpočtu přesné velikosti pole vyžadované GetBytes k uložení výsledných bajtů používá GetByteCountaplikace . K výpočtu maximální velikosti pole by měla aplikace použít GetMaxByteCount. Metoda GetByteCount obecně umožňuje přidělení menší paměti, zatímco GetMaxByteCount metoda obvykle provádí rychleji.

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

Ve většině případů tato metoda vrátí přiměřenou čísla pro malé řetězce. U velkých řetězců je možné, že budete muset zvolit použití velmi velkých vyrovnávacích pamětí a zachytávání chyb ve výjimečných případech, kdy je překročena přiměřenou vyrovnávací paměť. Můžete také zvážit jiný přístup, který používáte GetByteCount nebo Encoder.Convert. Zatímco UTF-7 je velmi efektivní při kódování dat ASCII, jeden bajt na znak, je extrémně neefektivní pro jiná data. Jak bylo uvedeno výše, GetMaxByteCount řeší nejhorší případ. Pokud jsou data zakódovaná z velké části ASCII, a zejména pokud jsou znaky ASCII společně, je UTF-7 výrazně efektivnější než číslo vrácené touto metodou navrhuje.

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

Poznámka

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

Platí pro

Viz také