String、StringBuilder类连接字符串操作的时间差异
生活随笔
收集整理的這篇文章主要介紹了
String、StringBuilder类连接字符串操作的时间差异
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
最新文章:Virson's Blog
剛剛看到園子里面寫了一篇關于Java的《StringBuilder、StringBuffer、String類之間的關系》的文章,自己也想試試看C#的String和StringBuilder類之間的差異,于是有了這篇文章:
CSharp代碼:
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 using System.Diagnostics; 7 8 namespace TestCharactor 9 { 10 class TestChar 11 { 12 private static int times = 50000; //循環次數 13 private static Stopwatch sw = new Stopwatch(); 14 15 static void Main(string[] args) 16 { 17 string tmpS = "adcdefg"; 18 StringBuilder tmpSb = new StringBuilder("abcdefg"); 19 sw.Start(); 20 Test(tmpS); 21 sw.Stop(); 22 Console.WriteLine("使用+操作符連接字符串共花費時間:{0}毫秒", sw.ElapsedMilliseconds); 23 sw.Restart(); 24 Test(tmpSb); 25 sw.Stop(); 26 Console.WriteLine("使用StringBuilder類連接字符串共花費時間:{0}毫秒", sw.ElapsedMilliseconds); 27 Console.ReadKey(); 28 } 29 30 public TestChar() 31 { 32 33 } 34 35 public static void Test(String s) 36 { 37 //sw.Start(); 38 for (int i = 0; i < times; ++i ) 39 { 40 s += "Virson Ma"; 41 } 42 //sw.Stop(); 43 //Console.WriteLine("使用+操作符連接字符串共花費時間:{0}毫秒", sw.ElapsedMilliseconds); 44 } 45 46 public static void Test(StringBuilder sb) 47 { 48 //sw.Restart(); 49 for (int i = 0; i < times; ++i ) 50 { 51 sb.Append("Virson Ma"); 52 } 53 //sw.Stop(); 54 //Console.WriteLine("使用StringBuilder類連接字符串共花費時間:{0}毫秒", sw.ElapsedMilliseconds); 55 } 56 } 57 }測試結果可以看出使用StringBuilder的Append方法比String的“+”操作要節省很多時間!
Result:
總結
以上是生活随笔為你收集整理的String、StringBuilder类连接字符串操作的时间差异的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 洛克王国烈火战神技能怎么配
- 下一篇: Bootstrap 3之美02-Grid