内容 |
用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 |