Chinaunix首页 | 论坛 | 博客
  • 博客访问: 184683
  • 博文数量: 42
  • 博客积分: 2520
  • 博客等级: 少校
  • 技术积分: 440
  • 用 户 组: 普通用户
  • 注册时间: 2009-05-18 09:54
文章分类
文章存档

2011年(1)

2010年(13)

2009年(28)

我的朋友

分类: LINUX

2010-12-07 18:28:23

参考:


分析:

当应用程序分配内存时,会调用到dalvik/vm/alloc/HeapSource.c中的 dvmTrackExternalAllocation()方法,继而调用到externalAllocPossible()方法,该方法要求当前堆已使 用的大小(由currentHeapSize和hs->externalBytesAllocated构成)加上我们需要再次分配的内存大小不能超 过堆的最大内存值,如果超过就会报错。
有两个地方决定了一个堆的最大内存:
1)dalvik/vm/Init.c中的
gDvm.heapSizeMax = 16 * 1024 * 1024;    // Spec says 75% physical mem
2)frameworks/base/core/jni/AndroidRuntime.cpp中的
property_get("dalvik.vm.heapsize", heapsizeOptsBuf+4, "16m");
因此解决办法就是将默认的16M改大一点。

解决办法:

1. 修改dalvik/vm/Init.c:

static void setCommandLineDefaults()
      * TODO: base these on a system or application-specific default
      */
     gDvm.heapSizeStart = 2 * 1024 * 1024; // Spec says 16MB; too big for us.

- gDvm.heapSizeMax = 16 * 1024 * 1024; // Spec says 75% physical mem

+ gDvm.heapSizeMax = 32 * 1024 * 1024; // Spec says 75% physical mem

     gDvm.stackSize = kDefaultStackSize;
 


2. 修改frameworks/base/core/jni/AndroidRuntime.cpp:

int AndroidRuntime::startVm(JavaVM** pJavaVM, JNIEnv** pEnv)
     //options[curOpt++].optionString = "-verbose:class";

 
     strcpy(heapsizeOptsBuf, "-Xmx");
- property_get("dalvik.vm.heapsize", heapsizeOptsBuf+4, "16m");
+ property_get("dalvik.vm.heapsize", heapsizeOptsBuf+4, "32m");
     //LOGI("Heap size: %s", heapsizeOptsBuf);

     opt.optionString = heapsizeOptsBuf;
     mOptions.add(opt);


阅读(3321) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~