问题引出:
StringBuilder sqlQuery = new StringBuilder();
sqlQuery.Append("SELECT COUNT([ProductID]) FROM ~~where [IsDelete]=‘F‘ );
1.StringBuilder和String的区别
String aa="123456";
aa+="789";
StringBuilder text=new StringBuilder("123456",12);
text.Append("789");
如果你输出aa,和text 你会发现他们的输出内容是一样的。
但是aa的操作过程实际上是:首先在内存中分配一个地址空间,空间大小是6。
然后执行 aa+="789";的操作,该过程是连接字符串,“123456”和“789”并且在内存中重新分配地址。把aa的内存地址指向 “123456789”的内存地址。
也就是说在内存中实际上是有两个空间被分配,第一的内存空间,在后来是由C#的垃圾处理机制来自动处理掉,如果我们用3 4 句的程序来实现这个过程,那么他是没有再次分配内存空间的,他就是在text的内存空间里进行了操作。这里要说明下StringBuilder在生命变量的过程中是可以我们自己来分配他的大小的,如果实际的内容超出内存空间,他会自动翻倍。
通过上面的例子,我们可以知道 StringBuilder的优越性是在:
第一:他不需要每次都去分配内存空间。所以系统就没有必要去处理垃圾;
第二:当我们需要多次的对一个字符串进行多次操作的时候,他的效率要远远 高 与string
2.Append
Append 方法可用来将文本或对象的字符串表示形式添加到由当前 StringBuilder 对象表示的字符串的结尾处。
StringBuilder.Append 将信息追加到当前 StringBuilder 的结尾。
StringBuilder.AppendFormat 用带格式文本替换字符串中传递的格式说明符。
StringBuilder.Insert 将字符串或对象插入到当前 StringBuilder 对象的指定索引处。
StringBuilder.Remove 从当前 StringBuilder 对象中移除指定数量的字符。