クリックして評価とフィードバックをお寄せください
MSDN
MSDN ライブラリ
.NET 開発
以前のバージョン
.NET Framework SDK 2.0
System.Text
StringBuilder クラス

  低帯域幅での表示をオンにする
このページは次のバージョンについて記述しています。
Microsoft Visual Studio 2005/.NET Framework 2.0

その他のバージョンについては、以下の情報を参照してください。
StringBuilder クラス
可変型の文字列を表します。このクラスは継承できません。

名前空間: System.Text
アセンブリ: mscorlib (mscorlib.dll 内)

Visual Basic (宣言)
<SerializableAttribute> _
<ComVisibleAttribute(True)> _
Public NotInheritable Class StringBuilder
	Implements ISerializable
Visual Basic (使用法)
Dim instance As StringBuilder
C#
[SerializableAttribute] 
[ComVisibleAttribute(true)] 
public sealed class StringBuilder : ISerializable
C++
[SerializableAttribute] 
[ComVisibleAttribute(true)] 
public ref class StringBuilder sealed : ISerializable
J#
/** @attribute SerializableAttribute() */ 
/** @attribute ComVisibleAttribute(true) */ 
public final class StringBuilder implements ISerializable
JScript
SerializableAttribute 
ComVisibleAttribute(true) 
public final class StringBuilder implements ISerializable
XAML
適用できません。

このクラスは、可変型の文字のシーケンスである値を持つ、文字列のようなオブジェクトを表します。文字を追加、削除、置換または挿入して値を作成した後にその値を変更できるため、値が可変型と呼ばれます。比較のため、String クラスのトピックを参照してください。

このクラスのインスタンスを変更するメソッドの多くは、同じインスタンスへの参照を返します。インスタンスへの参照が返されるため、参照に対してメソッドまたはプロパティを呼び出すことができます。これは、連続した操作を次々にチェイン化する単一のステートメントを書く場合に役立ちます。

StringBuilder の容量は、インスタンスが指定した時間に格納できる最大文字数で、インスタンスの値の文字列形式の長さ以上です。容量は、Capacity プロパティまたは EnsureCapacity メソッドを使用して増減できます。ただし、Length プロパティの値より小さくすることはできません。

StringBuilder のインスタンスが初期化されるときに、容量または最大容量が指定されなかった場合は、実装に固有の既定の容量が使用されます。

パフォーマンスに関する考慮事項

Concat メソッドと AppendFormat メソッドは、どちらも新しいデータを既存の String オブジェクトまたは StringBuilder オブジェクトに連結します。String オブジェクトの連結演算は、常に既存の文字列と新しいデータから新しいオブジェクトを作成します。一方、StringBuilder オブジェクトは、新しいデータの連結に使用するためのバッファを保持します。バッファに十分な容量がある場合は、新しいデータがバッファの末尾に追加されます。容量が足りない場合は、より大きなバッファが新しく割り当てられ、元のバッファから新しいバッファにデータがコピーされたうえで、新しいデータが新しいバッファに追加されます。

String または StringBuilder オブジェクトの連結演算のパフォーマンスは、メモリの割り当て頻度に依存しています。String の連結演算では、常にメモリが割り当てられます。一方、StringBuilder の連結演算では、StringBuilder オブジェクトのバッファに新しいデータのための十分な容量がない場合にのみ、メモリが割り当てられます。したがって、連結する String オブジェクトの数が決まっている場合は、String クラスを使用した方が効率的です。この場合、個々の連結演算は、コンパイラによって 1 つの演算に結合されます。これに対し、ランダムな数の文字列をユーザーから入力として受け取り、ループ処理で連結する場合など、連結する文字列の数が不定である場合は、StringBuilder オブジェクトが適しています。

実装元へのメモ : この実装の既定容量は 16 で、既定の最大容量は Int32.MaxValue です。 StringBuilder は、インスタンスの値が大きくなった場合に、文字を格納するために必要なより多くのメモリを割り当てることができます。それに応じて容量が調整されます。割り当てられたメモリの量が実装固有で、必要なメモリ量が最大容量より大きい場合は、ArgumentOutOfRangeException がスローされます。 たとえば、Append メソッド、AppendFormat メソッド、EnsureCapacity メソッド、Insert メソッド、および Replace メソッドはインスタンスの値を拡大できます。 StringBuilder の値内の個別の文字は、Chars プロパティを使用してアクセスできます。インデックスの位置は 0 から始まります。

次のコード例は、StringBuilder クラスで定義された多くのメソッドを呼び出す方法を示しています。

Visual Basic
<%@ Page Language="VB" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">

</script>

<html  >
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
               <atlas:ScriptManager runat="server" ID="ScriptManager1">
               </atlas:ScriptManager>
    </form>
</body>
</html>

<script type="text/javascript">

    Type.registerNamespace('Samples');
    Samples.StringBuilderExample = function()
    {
        this._headTagStart = "<head>";
        this._headTagEnd = "</head>";
        this._titleTagStart = "<title>";
        this._titleTagEnd = "</title>";
    }
    Samples.StringBuilderExample.prototype = 
    { 
        buildString: function(title) 
        {
            try
            {
                if (title === undefined) throw Error.argumentUndefined('title');
                if (title === null) throw Error.argumentNull('title');
                
                var sb = new Sys.StringBuilder(this._headTagStart);
                sb.append(this._titleTagEnd);
                sb.append(title);
                sb.append(this._titleTagEnd);
                sb.append(this._headTagEnd);
                // Displays: "The result is: <head><title>A Title</title></head>"
                alert("The result is: " + sb.toString()); 
            }
            catch(e)
            {
                // If debug mode then write extended exception information to the page.
                // Otherwise, show an alert.
                if(debug.isDebug)
                {
                  var msg = "(DEBUG MODE)</p>A CLIENT-SIDE RUNTIME EXCEPTION OCCURED:</p>" + e.message;
                  document.write(msg);
                }
                else
                {
                  alert(e.message);
                }
            }
        }
    }
    
    Samples.StringBuilderExample.registerClass('Samples.StringBuilderExample');
    
    var StringBuilderSampleVar = new Samples.StringBuilderExample();
    var title = "A Title";
    StringBuilderSampleVar.buildString(title);
    
</script>
C#
<%@ Page Language="C#" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
</script>

<html  >
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
               <atlas:ScriptManager runat="server" ID="ScriptManager1">
               </atlas:ScriptManager>
    </form>
</body>
</html>

<script type="text/javascript">

    Type.registerNamespace('Samples');
    Samples.StringBuilderExample = function()
    {
        this._headTagStart = "<head>";
        this._headTagEnd = "</head>";
        this._titleTagStart = "<title>";
        this._titleTagEnd = "</title>";
    }
    Samples.StringBuilderExample.prototype = 
    { 
        buildString: function(title) 
        {
            try
            {
                if (title === undefined) throw Error.argumentUndefined('title');
                if (title === null) throw Error.argumentNull('title');
                
                var sb = new Sys.StringBuilder(this._headTagStart);
                sb.append(this._titleTagEnd);
                sb.append(title);
                sb.append(this._titleTagEnd);
                sb.append(this._headTagEnd);
                // Displays: "The result is: <head><title>A Title</title></head>"
                alert("The result is: " + sb.toString()); 
            }
            catch(e)
            {
                // If debug mode then write extended exception information to the page.
                // Otherwise, show an alert.
                if(debug.isDebug)
                {
                  var msg = "(DEBUG MODE)</p>A CLIENT-SIDE RUNTIME EXCEPTION OCCURED:</p>" + e.message;
                  document.write(msg);
                }
                else
                {
                  alert(e.message);
                }
            }
        }
    }
    
    Samples.StringBuilderExample.registerClass('Samples.StringBuilderExample');
    
    var StringBuilderSampleVar = new Samples.StringBuilderExample();
    var title = "A Title";
    StringBuilderSampleVar.buildString(title);
    
</script>
System.Object
  System.Text.StringBuilder
この型の public static (Visual Basicでは共有) メンバはすべて,スレッド セーフです。インスタンス メンバの場合は,スレッド セーフであるとは限りません。

Windows 98,Windows Server 2000 SP4,Windows CE,Windows Millennium Edition,Windows Mobile for Pocket PC,Windows Mobile for Smartphone,Windows Server 2003,Windows XP Media Center Edition,Windows XP Professional x64 Edition,Windows XP SP2,Windows XP Starter Edition

Microsoft .NET Framework 3.0 は Windows Vista,Microsoft Windows XP SP2,および Windows Server 2003 SP1 でサポートされています。

.NET Framework

サポート対象 : 3.0,2.0,1.1,1.0

.NET Compact Framework

サポート対象 : 2.0,1.0

XNA Framework

サポート対象 : 1.0
コミュニティ コンテンツ   コミュニティ コンテンツとは
新しいコンテンツの追加 RSS  注釈
Processing
© 2009 Microsoft Corporation. All rights reserved. 使用条件  |  商標  |  プライバシー
Page view tracker