次の方法で共有


ASCIIEncoding.GetBytes メソッド (String, Int32, Int32, Byte , Int32)

String から指定した範囲の文字をエンコードし、その結果をバイト配列内の指定した範囲の要素に格納します。

Overrides Overloads Public Function GetBytes( _
   ByVal chars As String, _   ByVal charIndex As Integer, _   ByVal charCount As Integer, _   ByVal bytes() As Byte, _   ByVal byteIndex As Integer _) As Integer
[C#]
public override int GetBytes(stringchars,intcharIndex,intcharCount,byte[] bytes,intbyteIndex);
[C++]
public: int GetBytes(String* chars,intcharIndex,intcharCount,unsigned charbytes __gc[],intbyteIndex);
[JScript]
public override function GetBytes(
   chars : String,charIndex : int,charCount : int,bytes : Byte[],byteIndex : int) : int;

パラメータ

  • chars
    エンコードする文字列。
  • charIndex
    エンコードする chars 内の最初の文字のインデックス。
  • charCount
    エンコードする文字数。
  • bytes
    エンコードされた結果が格納されるバイト配列。
  • byteIndex
    エンコードされた結果が格納されている bytes 内の最初の要素のインデックス。

戻り値

bytes に格納されているバイト数。

例外

例外の種類 条件
ArgumentNullException chars または bytes が null 参照 (Visual Basic では Nothing) です。
ArgumentOutOfRangeException charIndexcharCount または byteIndex が 0 未満です。

または

charIndexcharCount を加算した値が、 chars の長さを超えています。

または

byteIndexbytes の長さを超えています。

ArgumentException bytes の長さから byteIndex を引いた値が charCount 未満です。

解説

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

使用例

[Visual Basic, C#, C++] GetBytes メソッドを使用して、String chars からある範囲の文字をエンコードし、その結果をバイト配列 bytes 内のある範囲の要素に格納する方法を次の例に示します。 GetByteCount メソッドは、エンコードされた文字を格納するために必要なバイト数を確認するときに使用します。

 
Imports System
Imports System.Text

Class ASCIIEncodingExample
   
    Public Shared Sub Main()
        Dim bytes() As Byte
        Dim chars As String = "ASCII Encoding Example"

        Dim ascii As New ASCIIEncoding()

        Dim byteCount As Integer = ascii.GetByteCount(chars.ToCharArray(), 6, 8)
        bytes = New Byte(byteCount - 1) {}
        Dim bytesEncodedCount As Integer = ascii.GetBytes(chars, 6, 8, bytes, 0)

        Console.WriteLine("{0} bytes used to encode string.", bytesEncodedCount)

        Console.Write("Encoded bytes: ")
        Dim b As Byte
        For Each b In bytes
            Console.Write("[{0}]", b)
        Next b
        Console.WriteLine()
    End Sub
End Class

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

class ASCIIEncodingExample {
    public static void Main() {
        Byte[] bytes;
        String chars = "ASCII Encoding Example";
        
        ASCIIEncoding ascii = new ASCIIEncoding();
        
        int byteCount = ascii.GetByteCount(chars.ToCharArray(), 6, 8);
        bytes = new Byte[byteCount];
        int bytesEncodedCount = ascii.GetBytes(chars, 6, 8, bytes, 0);
        
        Console.WriteLine(
            "{0} bytes used to encode string.", bytesEncodedCount
        );

        Console.Write("Encoded bytes: ");
        foreach (Byte b in bytes) {
            Console.Write("[{0}]", b);
        }
        Console.WriteLine();
    }
}

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

int main()
{
   Byte bytes[];
   String * chars = S"ASCII Encoding Example";

   ASCIIEncoding* ascii = new ASCIIEncoding();

   int byteCount = ascii -> GetByteCount(chars -> ToCharArray(), 6, 8);
   bytes = new Byte[byteCount];
   int bytesEncodedCount = ascii -> GetBytes(chars, 6, 8, bytes, 0);

   Console::WriteLine(S" {0} bytes used to encode string.", __box(bytesEncodedCount));

   Console::Write(S"Encoded bytes: ");
   IEnumerator* myEnum = bytes->GetEnumerator();
   while (myEnum->MoveNext())
   {
      Byte b = *__try_cast<Byte __gc*>(myEnum->Current);
      Console::Write(S"[{0}]", __box(b));
   }

   Console::WriteLine();
}

[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 名前空間 | ASCIIEncoding.GetBytes オーバーロードの一覧 | GetByteCount | GetMaxByteCount