- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我正在编写一个将大量联系人与 Android 联系人数据库同步的程序。对于大约 700 个联系人,下载工作正常,之后我不断收到内存堆错误,该错误调用无限数量的 GC 语句并最终重新启动手机。我正面临 HTC 渴望的问题。
我使用 DDMS 的堆分配工具检查了应用程序的堆大小,并使用 Debug.dumpHprofData 提取了 hprof 文件。两个日志都表明堆大小约为 2.4MB。
但是我得到以下日志,表明堆大小超过 32.MB
dalvikvm-heap(92): Clamp target GC heap from 33.999MB to 32.000MB
dalvikvm(92): GC_FOR_MALLOC freed 2 objects / 48 bytes in 313ms
我在循环中插入了以下日志语句,其中写入了我的联系人下载逻辑。
Log.e("Memory", "free mem =" +runtime.freeMemory());
Log.e("Memory", "total memory =" +runtime.totalMemory());
这些是打印语句的初始值和最终值
---------------------------------------------------------------
11-11 12:56:04.168: ERROR/Memory(25132): free mem =871248
11-11 12:56:04.168: ERROR/Memory(25132): total memory =4202464
---------------------------------------------------------------
11-11 13:01:55.408: ERROR/Memory(25132): free mem =891640
11-11 13:01:55.408: ERROR/Memory(25132): total memory =4726752
---------------------------------------------------------------
这表明在同步联系人逻辑中显然不存在内存泄漏。
有人可以告诉我为什么堆大小增加(高达 32.00Mb)到设备重新启动的程度吗?我是 Android 和 Java 新手,所以请放轻松:).....
最佳答案
虽然这不是最佳答案,但我强烈建议您观看 Memory management for Android Apps 的视频在 Google IO 2011 上发表演讲。它很好地解释了如何管理内存以及您看到的消息的实际含义。
关于java - Android dalvikvm-heap : Clamp target GC heap,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4155247/
使用 this link我能够使用正则表达式 (?!dalvikvm\b)\b\w+ 创建一个过滤器来过滤带有标签 dalvikvm 的消息,但我尝试了几种变体的正则表达式,例如 (?!dalvikv
出于某种原因,这个类做了太多工作并且滞后,这是我的应用程序上下文中的一个主要问题。当用户单击 map 上的某个位置时,它应该会快速获取该位置的地址,但不幸的是我暂停了 logCat dalvikvm,
我如何从带有输入的 .jar 文件开始使用 dalvikvm。类似的东西: dalvikvm -cp /path to jar/test.jar "hello" test.jar 的主要方法就是将这个
我有一种情况,我的 Android 应用程序无法及时执行软实时任务,因为调用垃圾收集器需要几毫秒。给予 GC 的几毫秒时间不足以错过一些重要的截止日期,这些小任务需要从 IO 设备读取数据。 本来想引
我正在努力寻找内存泄漏。我想第一步是通过查看 dalvikvm 看看我是否有一个,但我并不真正了解它是好是坏。这是我的 dalvikvm 日志的快照: 有人能简单说一下上面看到的内容吗?什么是危险信号
我在任何地方都找不到它们的记录。那么这个 Logcat 错误消息中的值是什么意思: 06-28 14:59:53.172: E/dalvikvm(32679): 32679(...) stat: (e
当我在手机上启动我的应用程序时,我从日志中收到了很多以下错误: E/dalvikvm( 2052): No free temp registers E/dalvikvm( 2052): Jit: ab
我正在尝试了解 Android 如何启动应用程序。问题是 Zygote 如何(以及为什么) fork 一个新的 Dalvik VM?我不明白为什么不能在同一个 Dalvik VM 中运行多个应用程序。
序言 我正在尝试使用 dex 文件的 Smali/Baksmali 汇编器/反汇编器来了解 DalvikVM 指令。 问题 来自这个java文件 package gd; class Hello {
所以我一直在研究如何使用 dalvikvm 在 Android 设备上运行 java 代码。我可以使用命令 dalvikvm -cp RunTest.dex RunTest 成功运行编译为 .dex
我正在尝试在终端中使用 dalvikvm 启动已安装的应用程序。如果我尝试这样做是行不通的: dalvikvm -cp /system/app/Calculator.apk com.android.c
我正在尝试来自 https://android.googlesource.com/platform/dalvik/+/gingerbread/docs/hello-world.html 的 Hello
当我触摸操作栏按钮时,我的 Android 应用程序出现锁定。我什至没有收到 ANR 对话。 我看到的唯一 LogCat 错误是: 02-01 14:59:15.328 30107-30170/com
我想知道 Handlers 在 Android/DalvikVM 中是如何处理的。我正在为 Android 编写一个应用程序,在一个类中我有一个 Handler 方法可以从另一个类接收消息。 Hand
这个问题是我的 earlier question 的后续问题. 这是来自该问题的相同示例。 import android.os.SystemClock; /** * Command that sen
我有一个非常简单的命令行 Java 应用程序,我希望将其移植到 Android 平台。该应用程序所做的是访问 Internet 上的网页并通过 System.out.println 打印一些输出。 来
我需要在 Android 上运行 java 应用程序的命令行版本(是的,我知道这并不简单)。 我尝试使用 Dalvikvm 启动它,它实际上启动了,但后来我的代码失败了,因为它开始使用 android
一般来说,Android 在 Dalvik Vm 中将每个应用程序作为一个单独的进程运行。我从 Doc 得到这个.但我不明白去Android的Dalvik VM的主要原因是什么。它比Java VM有什
我已经释放了每个对象,回收了 onDestroy() 方法中的所有位图: private void unbindDrawables(View view) { if (view.get
我需要在 Android 上运行 java 应用程序的命令行版本(是的,我知道这并不简单)。 我正在尝试使用 Dalvikvm 启动它,它确实启动了,但稍后我的代码失败了,因为它开始使用 androi
我是一名优秀的程序员,十分优秀!