C# 利用StringBuilder提升字符串拼接性能
一个项目中有数据图表呈现,数据量稍大时显得很慢。
用Stopwatch分段监控了一下,发现耗时最多的函数是SaveToExcel
此函数中遍列所有数据行,通过Replace替换标签生成Excel行,然后将行数据累加赋值到一个字符串
var excelString = ""; foreach(var item in list){ excelString += string.Format("<row>....{0}</row>",list.Title); }
看到这。。立马想起无数先烈们的警告、字符串拼接的内存操作原理等等。于是大手一挥,代码全删,改为如下形式
var excelString = new StringBuilder(); foreach(var item in list){ excelString.AppendFormat("<row>......{0}</row>",list.Title); }
再次测试,效率立马提升了几十倍。之前8000行需要30s,现在只需要2s