TC# 中的类是专为字符串操作而设计的命名空间的重要组成部分。与 C# 中的常规字符串不同,C# 中的常规字符串是不可变的,它提供了一个可变的字符串对象。这意味着可以修改它,而无需为每次修改创建新对象的开销,这在处理大型字符串或执行频繁的字符串操作时特别有用。StringBuilderSystem.TextStringBuilder
StringBuilder是可变的,这意味着它可以在创建后进行更改。相比之下,C# 中的常规字符串是不可变的。每次修改字符串时,都会创建一个新的字符串对象。在涉及频繁修改的方案中,这可能效率低下。 通过允许更改(例如追加、插入、删除或替换字符)来解决此问题,而无需每次都创建新实例。StringBuilder
实例化对象时,它会分配一个缓冲区以适应修改。此缓冲区具有默认容量,但当内容超过当前容量时,它可以自动扩展。与为每次修改创建新字符串相比,这种动态调整大小更节省内存。StringBuilder
在涉及大量字符串连接或修改的方案中,使用 或 的字符串连接性能明显优于字符串连接。这种性能提升是因为最大限度地减少了内存复制和分配开销。StringBuilder+String.ConcatStringBuilder
public static void Main(string[] args)
{
StringBuilder y = new StringBuilder();
y.Append("Dayanand");
AppendString(y);
Console.WriteLine(y);
}
public static void AppendString(StringBuilder x)
{
x.Append(" Thombare");
}
在第一种情况下,我们看到了 的基本用法。使用字符串“Dayanand”创建并初始化对象。然后,将该方法作为参数调用。在里面,字符串“Thombare”被附加到。这演示了如何动态增长大小,以及在方法中对其所做的更改如何由于其引用类型行为而反映在原始对象中。StringBuilderStringBuilderyAppendStringyAppendStringyStringBuilder
分析:
关键要点:该方法有效地将新字符串添加到现有内容的末尾。AppendStringBuilder
public static void Main(string[] args)
{
StringBuilder y = new StringBuilder();
y.Append("Dayanand");
AppendString(y);
Console.WriteLine(y.ToString());
Console.WriteLine(y == null);
}
public static void AppendString(StringBuilder x)
{
x = null;
}
在第二种方案中,尝试将参数设置为 null。但是,这不会影响 中使用的原始文件。null to 的赋值是 in 的本地值,不会更改 in 的引用。AppendStringStringBuilderxStringBuilderyMainxAppendStringyMain
分析:
关键要点:将 a 传递给方法会传递其引用。但是,更改方法内部的引用不会影响原始对象。StringBuilder
public static void Main(string[] args)
{
StringBuilder y = new StringBuilder();
y.Append("Dayanand");
AppendString(ref y);
Console.WriteLine(y.ToString());
Console.WriteLine(y == null);
}
public static void AppendString(ref StringBuilder x)
{
x = null;
}
在第三种方案中,使用关键字通过引用获取参数。当在 中设置为 null 时,它也会设置为 null。这是因为 和 是对同一对象的引用,而 using 意味着对引用本身的任何更改都反映在方法之外。AppendStringStringBuilderrefxAppendStringyMainxyStringBuilderref
分析:
关键要点:使用允许方法修改引用本身,而不仅仅是它指向的对象。ref
了解 C# 中的类对于在应用程序中高效地操作字符串至关重要。它的可变性,加上高效的内存管理,使其成为需要频繁或复杂字符串操作的场景不可或缺的工具。通过在常规字符串和 之间仔细选择,并了解将实例传递给方法的含义,可以编写更高效、更可维护的 C# 代码。