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

字號:


    用Stopwatch分段監(jiān)控了一下,發(fā)現耗時最多的函數是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