android-为什么这些内存分配数字不累加?
作者:互联网
我在adb logcat窗口中看到以下内容:
01-24 14:40:56.916: E/dalvikvm-heap(24727): 1957200-byte external allocation too large for this process.
01-24 14:40:56.966: E/GraphicsJNI(24727): VM won't let us allocate 1957200 bytes
01-24 14:40:56.976: E/dalvikvm(24727): OutOfMemory: max: 50331648(49152 K), total: 39985120(39047 K), alloc: 33659240(32870 K), extAlloc: 8993870(8783 K)
我不明白的是为什么这些数字没有加起来(或者我只是不明白这是如何工作的).我看到OutOfMemory:基本上最大为48MB,我认为这是最大堆大小.不确定此上下文中的“总计”是什么,但看起来大约为39MB. 2MB分配失败了,我真的不明白为什么会失败,应该有9MB可用…我在这里误解了什么?
解决方法:
欢迎来到堆碎片的美好世界.简而言之,您需要一个连续的内存块来满足分配,而不仅仅是足够的可用字节.
例如,想象一个空的1MB堆.现在想象一下,在那1MB中间就是1K分配.即使您有99.9%的可用空间,也不能分配超过500K的空间,因为它必须是连续的.移动该1K分配,您可以分配更多,但在病理情况下,最终可能拥有比分配更多的可用内存.
对于您的情况,我敢打赌,如果您尝试进行2000个1K分配,效果会很好.这会让您知道您是否正在处理碎片或其他问题.
标签:memory,out-of-memory,android 来源: https://codeday.me/bug/20191101/1986137.html