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? 显示到控制台。