- 内存不足?代码错误?都不是
昨天写一个处理从DB 中导出图片的东西,原理很简单,就是将数据库中的二进制导出为图片(JPG),但是数据量非常大(超过10万行数据,DB超过80GB),代码很快写完,但是在测试过程中,有图片因为内存不足而导出失败,并且大约执行到2000条左右时,因内存不足而终止执行,最开始没有发现,想的是毕竟数据量大,内存不足正常,还想到了直接将执行失败的数据标记出来,另外再执行(点开软件,接着没执行完的继续执行),至于因内存不足导出失败的记录,开始的想法是再加一个功能按钮,毕竟执行失败的几率已经用一个文本单独记录了,添加进来继续执行呗。然而今早过来,习惯性的重新读一遍自己的代码的时候,发现逻辑上,总体没问题,然而,当看到数据库打开(代码中“标记1”)后,关闭是在代码执行完(代码中“//标记5”),或许是早上脑袋还清醒,突然反应过来,数据库打开后,没有及时关闭,导致内存不断上涨,后面试了,“打开使用后及时关闭”(增加了代码中的“标记2”和“标记3”,一关闭一打开。同时“标记5”关闭相应的移动到“标记4”位置),一测试,10万+的记录顺利执行完毕,内存一直维持在20%(14G)左右。
搞不懂的是,为什么内存超过 25%就会直接中断?BUG?求教
下附部分代码
C# 处理Sqlite(DB)内存不足?代码错误?都不是
于 2024-05-30 14:31:56 首次发布