UnicodeEncoding.GetMaxByteCount(Int32) メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
指定した文字数をエンコードすることによって生成される最大バイト数を計算します。
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
パラメーター
- charCount
- Int32
エンコードする文字数。
戻り値
指定した文字数をエンコードすることによって生成される最大バイト数。
例外
例
次の例では、 メソッドを使用 GetMaxByteCount して、指定した文字数をエンコードするために必要な最大バイト数を返す方法を示します。
using namespace System;
using namespace System::Text;
int main()
{
UnicodeEncoding^ Unicode = gcnew UnicodeEncoding;
int charCount = 2;
int maxByteCount = Unicode->GetMaxByteCount( charCount );
Console::WriteLine( "Maximum of {0} bytes needed to encode {1} characters.", maxByteCount, charCount );
}
using System;
using System.Text;
class UnicodeEncodingExample {
public static void Main() {
UnicodeEncoding Unicode = new UnicodeEncoding();
int charCount = 2;
int maxByteCount = Unicode.GetMaxByteCount(charCount);
Console.WriteLine(
"Maximum of {0} bytes needed to encode {1} characters.",
maxByteCount,
charCount
);
}
}
Imports System.Text
Class UnicodeEncodingExample
Public Shared Sub Main()
Dim uni As New UnicodeEncoding()
Dim charCount As Integer = 2
Dim maxByteCount As Integer = uni.GetMaxByteCount(charCount)
Console.WriteLine("Maximum of {0} bytes needed to encode {1} characters.", maxByteCount, charCount)
End Sub
End Class
注釈
結果のバイトを格納するために に GetBytes 必要な正確な配列サイズを計算するために、アプリケーションでは を使用 GetByteCountします。 配列の最大サイズを計算するには、アプリケーションで を使用 GetMaxByteCountする必要があります。 メソッドは通常、割り当てるメモリが少なくなりますが、メソッドの実行速度は GetByteCount 一般に GetMaxByteCount 速くなります。
GetMaxByteCount現在選択されているの最悪のケースを含む、最悪のケース番号を取得し EncoderFallback ます。 フォールバックが大きくなる可能性がある文字列で選択された場合、 GetMaxByteCount は大きな値を返すことができます。
ほとんどの場合、このメソッドは小さい文字列に対して適切な数値を取得します。 大きな文字列の場合は、非常に大きなバッファーを使用して、より合理的なバッファーを超えるまれなケースでエラーをキャッチするかを選択する必要がある場合があります。 またはを使用して別の方法を検討することもでき GetByteCountEncoder.Convert ます。
GetMaxByteCountには関係がありません GetChars 。 アプリケーションで GetCharsを使用するために同様の関数が必要な場合は、 を使用 GetMaxCharCountする必要があります。
注意
GetMaxByteCount(N)
はと同じ値であるとは限りません N* GetMaxByteCount(1)
。
適用対象
こちらもご覧ください
.NET