萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> 編程語言綜合 >> C# 利用StringBuilder提升字符串拼接性能的小例子

C# 利用StringBuilder提升字符串拼接性能的小例子

用Stopwatch分段監控了一下,發現耗時最多的函數是SaveToExcel

此函數中遍列所有數據行,通過Replace替換標簽生成Excel行,然後將行數據累加賦值到一個字符串

復制代碼 代碼如下:
string excelString = "";
foreach(var item in list){
        excelString += string.Format("<row>....{0}</row>",list.Title);
}


看到這。。立馬想起無數先烈們的警告、字符串拼接的內存操作原理等等。於是大手一揮,代碼全刪,改為如下形式

復制代碼 代碼如下:
string excelString = new StringBuilder();
foreach(var item in list){
      excelString.AppendFormat("<row>......{0}</row>",list.Title);
}


再次測試,效率立馬提升了幾十倍。之前8000行需要30s,現在只需要2s

copyright © 萬盛學電腦網 all rights reserved