加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

StringBuilder内存不足C#

发布时间:2020-12-15 05:12:40 所属栏目:Java 来源:网络整理
导读:这是我想要实现的目标.循环遍历超过100万条记录的数据集,并在文本文件中创建数据转储导出到C盘. 我正在循环遍历超过一百万条记录的数据集.这是循环内部的内容 我在循环中使用StringBuilder. myString.Append(ds.tables[0](i)(0)); -- each datarow is not mo
这是我想要实现的目标.循环遍历超过100万条记录的数据集,并在文本文件中创建数据转储导出到C盘.

我正在循环遍历超过一百万条记录的数据集.这是循环内部的内容

我在循环中使用StringBuilder.

myString.Append(ds.tables[0](i)(0));  <-- each datarow is not more than 10 char long.

它抛出一个错误,说内存不足.我有12 gb的Ram.

我该如何解决这个问题呢?

解决方法

不要使用中间的StringBuilder – 它的内容可以放在你的计算机的RAM中,然后你可能会调用.ToString()来将结果写入磁盘.相反,在处理数据时将数据写入磁盘,例如:

using (var sw = new StreamWriter(outputFilePath,true)) 
{
    // start loop
        sw.Write(ds.tables[0](i)(0));
    // end loop
}

这将使用默认编码(UTF-8)和缓冲区大小(我认为它是4KB)将文本写入文件.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读