1
4
这不是处理内存管理的好方法。当您看到MemoryError时,您已经处于一个关键状态,内核可能接近于终止进程以释放内存,而在许多系统上,您将永远看不到它,因为它将去交换或只是OOM终止您的进程,而不是失败的分配。
如果希望缓存根据其他分配的需要释放内存,则它不需要与 错误 ,但使用分配器本身。这样,当您需要释放内存进行分配时,您将知道 需要连续内存,否则您将盲目猜测。这也意味着您可以在内存分配发生时跟踪它们,以便将内存使用率保持在特定的级别,而不是让它不受限制地增长,然后在它变得太高时尝试恢复。 我强烈建议,对于大多数应用程序来说,这种缓存行为是过度复杂的,不过——您通常最好只使用设置数量的内存进行缓存。 |
2
1
|
3
1
我希望我能对格伦的回答发表评论。。。虽然我同意不使用MemoryException作为处理缓存大小的方法的总体想法,但这并不一定意味着当您捕获它们时,您的系统会崩溃。有些人运行时没有交换,当使用ulimit来限制最大进程大小时,您也可以得到他们。另外,当使用软限制时,您甚至可以提高软限制来优雅地处理内存耗尽时的死亡(假设有一种方法可以提高它而不分配任何内存;我还没有尝试过)。
您可以这样挂接异常处理程序:
参数包括异常类、异常实例和回溯对象。可以按相同的顺序将这些参数传递给traceback.format_exception(),以生成python在未捕获异常时写入stderr的回溯消息。
|
TheKing · 为什么数组的地址可以有负值? 2 年前 |
yurnero · MATLAB:“加载”一个快速访问功能 6 年前 |
joe · 一页可以同时在两个工作集中吗? 6 年前 |
Jaques · “.exe”已触发断点 6 年前 |
adn bps · 在函数中修改变量的高效内存方法 6 年前 |
Gauraang Khurana · C语言中分段错误的不稳定行为 6 年前 |
Rajesh K · 如何查找设备中存在的广告垃圾? 6 年前 |