使用Excel XML String的System.Text.StringBuilder.ToString()的System.OutOfMemoryException

时间:2013-04-27 00:19:24

标签: c# asp.net .net out-of-memory stringbuilder

所以最近我一直在研究C#/ ASP.NET中的代码,它在选择大型参数时会抛出错误:

  

抛出了类型'System.OutOfMemoryException'的异常。在   System.Text.StringBuilder.ToString()

概述: 代码根据用户的选择从数据库中查询大量数据,并将其放入Excel文档中,然后由用户导出/下载。它首先使用StringBuilder来附加XML的前缀:

const string startExcelXML = "<xml version>\r\n<Workbook " +
"xmlns=\"urn:schemas-microsoft-com:office:spreadsheet\"\r\n" +
" xmlns:o=\"urn:schemas-microsoft-com:office:office\"\r\n " +
"xmlns:x=\"urn:schemas-    microsoft-com:office:" +
"excel\"\r\n xmlns:ss=\"urn:schemas-microsoft-com:" +
"office:spreadsheet\">\r\n <Styles>\r\n " +
"<Style ss:ID=\"Default\" ss:Name=\"Normal\">\r\n " +
"<Alignment ss:Vertical=\"Bottom\"/>\r\n <Borders/>" +
"\r\n <Font/>\r\n <Interior/>\r\n <NumberFormat/>" +
"\r\n <Protection/>\r\n </Style>\r\n " +
"<Style ss:ID=\"BoldColumn\">\r\n <Font " +
"x:Family=\"Swiss\" ss:Bold=\"1\"/>\r\n </Style>\r\n " +
"<Style     ss:ID=\"StringLiteral\">\r\n <NumberFormat" +
" ss:Format=\"@\"/>\r\n </Style>\r\n <Style " +
"ss:ID=\"Decimal\">\r\n <NumberFormat " +
"ss:Format=\"0.0000\"/>\r\n </Style>\r\n " +
"<Style ss:ID=\"Integer\">\r\n <NumberFormat " +
"ss:Format=\"0\"/>\r\n </Style>\r\n <Style " +
"ss:ID=\"DateLiteral\">\r\n <NumberFormat " +
"ss:Format=\"mm/dd/yyyy;@\"/>\r\n </Style>\r\n " +
"</Styles>\r\n ";

然后经过一个循环,并根据需要附加</Data></Cell>之类的内容,然后再附加:

const string endExcelXML = "</Workbook>";

然后它return contentSB.ToString();因为这是异常引用的方法中唯一的ToString(),所以 就是这段代码。

类似StackOverflow问题: interesting OutOfMemoryException with StringBuilder

思想: 我已经尝试使用下面的代码来大致了解字符串的大小,它适用于较小的选择,但不输出任何更大的选择,其中contentSB是StringBuilder对象:

    System.Diagnostics.Debug.WriteLine("String:", contentSB);
    System.Diagnostics.Debug.WriteLine("String length:", contentSB.Length);

引用的其他StackOverflow问题在附加时发生,而我的是在返回ToString()时,因此问题的原因可能不同,因为它不是在循环中追加的中间,而是在转换过程中返回。根本原因是什么?如何解决?