首页 > 代码库 > StringBuild,StringFormat," "+" " 三种方法速度测试

StringBuild,StringFormat," "+" " 三种方法速度测试

测试方式:

Stopwatch sw = new Stopwatch();sw.Start();string tmp = "";StringBuilder sb = new StringBuilder();for (int i = 0; i < 10000; i++){    //tmp += "|" + i;    sb.Append("|");    sb.Append(i.ToString());    //tmp = string.Format("{0}{1}{2}", tmp, "|", i);}sw.Stop();Console.WriteLine(sb.ToString());Console.WriteLine(sw.ElapsedMilliseconds);Console.Read();
View Code

 

创建一个1万次for循环,把i的数字相加,并以|分割。

不同类型组合StringFormat会比+稍快一些。但是组合多了之后反而比+更慢。

3个参数以内且不同类型或者格式复杂用StringFormat合适。(很长的字符串比"+"更慢)

大于3个参数,相同类型比较多,用+。

更加复杂考虑StringBuild

 

 

名称速度
StringBuild2ms
StringFormat655ms
+和StringFormat配合172ms
+181ms

 

注:+和StringFormat配合是指:tmp += string.Format("{0}{1}", "|", i);

StringBuild,StringFormat," "+" " 三种方法速度测试