是否可以在加载后推迟垃圾回收

时间:2012-07-20 16:00:53

标签: android jpct

我正在将3d模型(1MB - 10MB)加载到内存中需要很长时间(1.5MB型号为20秒)。当我查看日志时,我发现垃圾收集器不断释放内存并暂停。请参阅下面的日志:

07-20 17:37:25.340: D/dalvikvm(2826): GC_FOR_ALLOC freed <1K, 8% free 79443K/85575K, paused 86ms
07-20 17:37:25.350: I/dalvikvm-heap(2826): Grow heap (frag case) to 78.511MB for 852408-byte allocation
07-20 17:37:25.450: D/dalvikvm(2826): GC_FOR_ALLOC freed <1K, 8% free 80275K/86471K, paused 95ms
07-20 17:37:25.550: D/dalvikvm(2826): GC_FOR_ALLOC freed <1K, 8% free 80275K/86471K, paused 85ms
07-20 17:37:25.550: I/dalvikvm-heap(2826): Grow heap (frag case) to 79.325MB for 852408-byte allocation
07-20 17:37:25.660: D/dalvikvm(2826): GC_FOR_ALLOC freed <1K, 8% free 81108K/87367K, paused 96ms
07-20 17:37:25.760: D/dalvikvm(2826): GC_FOR_ALLOC freed 0K, 8% free 81108K/87367K, paused 87ms
07-20 17:37:25.760: I/dalvikvm-heap(2826): Grow heap (frag case) to 80.137MB for 852408-byte allocation
07-20 17:37:25.870: D/dalvikvm(2826): GC_FOR_ALLOC freed <1K, 8% free 81940K/88263K, paused 98ms
07-20 17:37:26.060: D/dalvikvm(2826): GC_CONCURRENT freed <1K, 5% free 83988K/88263K, paused 3ms+12ms
07-20 17:37:26.200: D/dalvikvm(2826): GC_FOR_ALLOC freed <1K, 5% free 84715K/88263K, paused 120ms
07-20 17:37:26.200: I/dalvikvm-heap(2826): Grow heap (frag case) to 83.660MB for 852312-byte allocation
07-20 17:37:26.310: D/dalvikvm(2826): GC_FOR_ALLOC freed 0K, 5% free 85547K/89159K, paused 102ms
07-20 17:37:26.420: D/dalvikvm(2826): GC_FOR_ALLOC freed <1K, 5% free 85547K/89159K, paused 95ms
07-20 17:37:26.420: I/dalvikvm-heap(2826): Grow heap (frag case) to 84.473MB for 852312-byte allocation
07-20 17:37:26.520: D/dalvikvm(2826): GC_FOR_ALLOC freed <1K, 5% free 86379K/90055K, paused 105ms
07-20 17:37:26.640: D/dalvikvm(2826): GC_FOR_ALLOC freed <1K, 4% free 87212K/90055K, paused 117ms
07-20 17:37:26.650: I/dalvikvm-heap(2826): Grow heap (frag case) to 86.098MB for 852312-byte allocation
...

是否可以推迟垃圾收集,直到加载模型为止。还欢迎任何其他性能提示:)

3 个答案:

答案 0 :(得分:2)

不,你不能推迟垃圾收集或以任何其他方式控制它。

但您可以使用DDMS中的Allocation Tracker来确定您在何处创建新对象。尝试重用相同的对象和缓冲区,避免自动装箱等。 关于使用Allocation Tracker的{​​{3}}可能会有所帮助。

答案 1 :(得分:1)

没有

无论如何,如果您在日志中注意到,VM正在努力争取内存。它有5%免费。 执行GC以继续运行您的应用。

此外,如果可以的话,你不想这样做。数十年来,智能人员开发出了最佳的垃圾收集算法不要试着比我聪明。

答案 2 :(得分:1)

不,这是不可能的,虚拟机处理这个并且它不可更改。但是为了加速加载模型,您可以考虑使用序列化对象而不是.3ds / .obj / ...文件。它们加载速度更快,占用内存更少。

检查wiki有关jpct和序列化对象的信息。