String 對象是不可改變的。每次使用 System.String 類中的方法之一時,都要在內存中建立一個新的字符串對象,這就須要爲該新對象分配新的空間。在須要對字符串執行重複修改的狀況下,與建立新的 String 對象相關的系統開銷可能會很是昂貴。若是要修改字符串而不建立新的對象,則可使用 System.Text.StringBuilder 類。例如,當在一個循環中將許多字符串鏈接在一塊兒時,使用 StringBuilder 類能夠提高性能。
經過用一個重載的構造函數方法初始化變量,能夠建立 StringBuilder 類的新實例,正如如下示例中所闡釋的那樣。 函數
1 StringBuilder MyStringBuilder = new StringBuilder("Hello World!"); 性能
設置容量和長度
雖然 StringBuilder 對象是動態對象,容許擴充它所封裝的字符串中字符的數量,可是您能夠爲它可容納的最大字符數指定一個值。此值稱爲該對象的容量,不該將它與當前 StringBuilder 對象容納的字符串長度混淆在一塊兒。例如,能夠建立 StringBuilder 類的帶有字符串「Hello」(長度爲 5)的一個新實例,同時能夠指定該對象的最大容量爲 25。當修改 StringBuilder 時,在達到容量以前,它不會爲其本身從新分配空間。當達到容量時,將自動分配新的空間且容量翻倍。可使用重載的構造函數之一來指定 StringBuilder 類的容量。如下代碼示例指定能夠將 MyStringBuilder 對象擴充到最大 25 個空白。 ui
1 StringBuilder MyStringBuilder = new StringBuilder("Hello World!", 25); spa
另外,可使用讀/寫 Capacity 屬性來設置對象的最大長度。如下代碼示例使用 Capacity 屬性來定義對象的最大長度。 orm
1 MyStringBuilder.Capacity = 25;對象
EnsureCapacity 方法可用來檢查當前 StringBuilder 的容量。若是容量大於傳遞的值,則不進行任何更改;可是,若是容量小於傳遞的值,則會更改當前的容量以使其與傳遞的值匹配。
也能夠查看或設置 Length 屬性。若是將 Length 屬性設置爲大於 Capacity 屬性的值,則自動將 Capacity 屬性更改成與 Length 屬性相同的值。若是將 Length 屬性設置爲小於當前 StringBuilder 對象內的字符串長度的值,則會縮短該字符串。
修改 StringBuilder 字符串
下表列出了能夠用來修改 StringBuilder 的內容的方法。
方法名 使用
StringBuilder.Append 將信息追加到當前 StringBuilder 的結尾。
StringBuilder.AppendFormat 用帶格式文本替換字符串中傳遞的格式說明符。
StringBuilder.Insert 將字符串或對象插入到當前 StringBuilder 對象的指定索引處。
StringBuilder.Remove 從當前 StringBuilder 對象中移除指定數量的字符。
StringBuilder.Replace 替換指定索引處的指定字符。
Append
Append 方法可用來將文本或對象的字符串表示形式添加到由當前 StringBuilder 對象表示的字符串的結尾處。如下示例將一個 StringBuilder 對象初始化爲「Hello World」,而後將一些文本追加到該對象的結尾處。將根據須要自動分配空間。 索引
1 StringBuilder MyStringBuilder = new StringBuilder("Hello World!");
2 MyStringBuilder.Append(" What a beautiful day.");
3 Console.WriteLine(MyStringBuilder); 接口
此示例將 Hello World! What a beautiful day. 顯示到控制檯。
AppendFormat
AppendFormat 方法將文本添加到 StringBuilder 的結尾處,並且實現了 IFormattable 接口,所以可接受格式化部分中描述的標準格式字符串。可使用此方法來自定義變量的格式並將這些值追加到 StringBuilder 的後面。如下示例使用 AppendFormat 方法將一個設置爲貨幣值格式的整數值放置到 StringBuilder 的結尾。 內存
1 int MyInt = 25;
2 StringBuilder MyStringBuilder = new StringBuilder("Your total is ");
3 MyStringBuilder.AppendFormat("{0:C} ", MyInt);
4 Console.WriteLine(MyStringBuilder); ci
此示例將 Your total is $25.00 顯示到控制檯。
Insert
Insert 方法將字符串或對象添加到當前 StringBuilder 中的指定位置。如下示例使用此方法將一個單詞插入到 StringBuilder 的第六個位置。
1 StringBuilder MyStringBuilder = new StringBuilder("Hello World!");
2 MyStringBuilder.Insert(6,"Beautiful ");
3 Console.WriteLine(MyStringBuilder);
此示例將 Hello Beautiful World! 顯示到控制檯。
Remove
可使用 Remove 方法從當前 StringBuilder 中移除指定數量的字符,移除過程從指定的從零開始的索引處開始。如下示例使用 Remove 方法縮短 StringBuilder。
1 StringBuilder MyStringBuilder = new StringBuilder("Hello World!");
2 MyStringBuilder.Remove(5,7);
3 Console.WriteLine(MyStringBuilder);
此示例將 Hello 顯示到控制檯。
Replace
使用 Replace 方法,能夠用另外一個指定的字符來替換 StringBuilder 對象內的字符。如下示例使用 Replace 方法來搜索 StringBuilder 對象,查找全部的感嘆號字符 (!),並用問號字符 (?) 來替換它們。
1 StringBuilder MyStringBuilder = new StringBuilder("Hello World!");
2 MyStringBuilder.Replace('!', '?');
3 Console.WriteLine(MyStringBuilder);
此示例將 Hello World? 顯示到控制檯。