我有一个使用SimpleFramework进行 XML 序列化的 Android 应用程序。该应用程序在我测试过的所有真实设备上运行良好,没有滞后,但在模拟器上运行时,垃圾收集器在每次启动应用程序时运行大约 3 分钟。
这是我到目前为止观察到的:
- 垃圾收集在将对象序列化为 XML 之前启动
- 它只发生在第一个对象被序列化并通过网络发送之前,并且不会发生在连续调用中。
- 序列化代码位于单独的库中,该库被打包并作为 .jar 文件添加到项目中。
这是 LogCat 的输出:
07-27 08:17:10.275: D/dalvikvm(682): GC_FOR_MALLOC freed 10179 objects / 482344 bytes in 32ms
07-27 08:17:10.435: D/dalvikvm(682): GC_FOR_MALLOC freed 13927 objects / 535968 bytes in 33ms
....... About 300 more similar entries...
这是我目前用于序列化的代码:
public String fromElement(Object request) {
Writer writer = new StringWriter();
try {
serializer.write(request, writer);
String res = writer.toString();
Log.d(LOG_TAG, res);
return writer.toString();
} catch (Exception e) {
e.printStackTrace();
}
return "";
}
显然,这会占用大量时间,每次我更改代码并重新部署应用程序时。有没有其他人在使用 libaray 时遇到过这种情况,如果是这样,有什么方法可以防止每次启动应用程序时(从 Eclipse)启动 GC 吗?增加堆(当前设置为vm.heapSize=24
)会有所帮助吗?还是有不同的解决方案?