次の方法で共有


ASCIIEncoding.GetMaxByteCount メソッド

指定した文字数をエンコードするために必要な、最大バイト数を計算します。

Overrides Public Function GetMaxByteCount( _
   ByVal charCount As Integer _) As Integer
[C#]
public override int GetMaxByteCount(intcharCount);
[C++]
public: int GetMaxByteCount(intcharCount);
[JScript]
public override function GetMaxByteCount(
   charCount : int) : int;

パラメータ

  • charCount
    エンコードする文字数。

戻り値

charCount の文字数の文字をエンコードするために必要な、最大バイト数。

例外

例外の種類 条件
ArgumentOutOfRangeException charCount が 0 未満です。

解説

このメソッドは、現在のエンコーディングの ASCIIEncoding.GetBytes に渡されたバイト配列の、最大バッファ サイズを判断するために使用します。この最大バッファ サイズを使用すると、バッファのオーバーフローによる例外が発生するのを防ぎます。

エンコードされた文字を格納するために GetBytes メソッドによって要求された配列サイズを、正確に計算するには GetByteCount を使用し、最大値を計算するには GetMaxByteCount を使用します。

使用例

[Visual Basic, C#, C++] 指定した文字数をエンコードするために必要なバイト数を、 GetMaxByteCount メソッドを使用して計算する方法を次の例に示します。

 
Imports System
Imports System.Text

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

[C#] 
using System;
using System.Text;

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

[C++] 
#using <mscorlib.dll>
using namespace System;
using namespace System::Text;

int main()
{
   ASCIIEncoding* ascii = new ASCIIEncoding();
   int charCount = 2;
   int maxByteCount = ascii -> GetMaxByteCount(charCount);
   Console::WriteLine(S"Maximum of {0} bytes needed to encode {1} characters.",
      __box(maxByteCount), __box(charCount));
}

[JScript] JScript のサンプルはありません。Visual Basic、C#、および C++ のサンプルを表示するには、このページの左上隅にある言語のフィルタ ボタン 言語のフィルタ をクリックします。

必要条件

プラットフォーム: Windows 98, Windows NT 4.0, Windows Millennium Edition, Windows 2000, Windows XP Home Edition, Windows XP Professional, Windows Server 2003 ファミリ, .NET Compact Framework - Windows CE .NET, Common Language Infrastructure (CLI) Standard

参照

ASCIIEncoding クラス | ASCIIEncoding メンバ | System.Text 名前空間 | GetBytes | GetBytes