修改android最小堆内存

简介: 在oncreate的时候加入如下代码段即可保证该运行程序有足够的内存了: [java] view plaincopy int CWJ_HEAP_SIZE = 10 * 1024 * 1024;  //10M的内存  VMRuntime.getRuntime().setMinimumHeapSize(CWJ_HEAP_SIZE);   别忘了导入包:

在oncreate的时候加入如下代码段即可保证该运行程序有足够的内存了:

  1. int CWJ_HEAP_SIZE = 10 * 1024 * 1024;  //10M的内存  
  2. VMRuntime.getRuntime().setMinimumHeapSize(CWJ_HEAP_SIZE);  


别忘了导入包:

  1. import dalvik.system.VMRuntime;  


深层理解,进入andorid源码内部:

当应用程序分配内存时,会调用到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:

[plain] view plain copy
  1. static void setCommandLineDefaults()  
  2.       * TODO: base these on a system or application-specific default  
  3.       */  
  4.      gDvm.heapSizeStart = 2 * 1024 * 1024; // Spec says 16MB; too big for us.  
  5.   
  6. - gDvm.heapSizeMax = 16 * 1024 * 1024; // Spec says 75% physical mem  
  7.   
  8. + gDvm.heapSizeMax = 32 * 1024 * 1024; // Spec says 75% physical mem  
  9.   
  10.      gDvm.stackSize = kDefaultStackSize;  


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

[plain] view plain copy
  1. int AndroidRuntime::startVm(JavaVM** pJavaVM, JNIEnv** pEnv)  
  2.      //options[curOpt++].optionString = "-verbose:class";  
  3.   
  4.    
  5.      strcpy(heapsizeOptsBuf, "-Xmx");  
  6. - property_get("dalvik.vm.heapsize", heapsizeOptsBuf+4, "16m");  
  7. + property_get("dalvik.vm.heapsize", heapsizeOptsBuf+4, "32m");  
  8.      //LOGI("Heap size: %s", heapsizeOptsBuf);  
  9.   
  10.      opt.optionString = heapsizeOptsBuf;  
  11.      mOptions.add(opt);  
  12.   
目录
相关文章
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
2199 1
|
监控 Java
压力测试Jmeter的简单使用,性能监控-堆内存与垃圾回收 -jvisualvm的使用
这篇文章介绍了如何使用JMeter进行压力测试,包括测试前的配置、测试执行和结果查看。同时,还探讨了性能监控工具jconsole和jvisualvm的使用,特别是jvisualvm,它可以监控内存泄露、跟踪垃圾回收、执行时内存和CPU分析以及线程分析等,文章还提供了使用这些工具的详细步骤和说明。
压力测试Jmeter的简单使用,性能监控-堆内存与垃圾回收 -jvisualvm的使用
|
算法 Java
堆内存分配策略解密
本文深入探讨了Java虚拟机中堆内存的分配策略,包括新生代(Eden区和Survivor区)与老年代的分配机制。新生代对象优先分配在Eden区,当空间不足时执行Minor GC并将存活对象移至Survivor区;老年代则用于存放长期存活或大对象,避免频繁内存拷贝。通过动态对象年龄判定优化晋升策略,并介绍Full GC触发条件。理解这些策略有助于提高程序性能和稳定性。
|
缓存 算法 Java
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
这篇文章详细介绍了Java虚拟机(JVM)中的垃圾回收机制,包括垃圾的定义、垃圾回收算法、堆内存的逻辑分区、对象的内存分配和回收过程,以及不同垃圾回收器的工作原理和参数设置。
846 4
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
|
存储 算法 Java
Java 内存管理与优化:掌控堆与栈,雕琢高效代码
Java内存管理与优化是提升程序性能的关键。掌握堆与栈的运作机制,学习如何有效管理内存资源,雕琢出更加高效的代码,是每个Java开发者必备的技能。
317 5
|
缓存 Java 测试技术
谷粒商城笔记+踩坑(11)——性能压测和调优,JMeter压力测试+jvisualvm监控性能+资源动静分离+修改堆内存
使用JMeter对项目各个接口进行压力测试,并对前端进行动静分离优化,优化三级分类查询接口的性能
689 10
谷粒商城笔记+踩坑(11)——性能压测和调优,JMeter压力测试+jvisualvm监控性能+资源动静分离+修改堆内存
|
算法 Java
JVM进阶调优系列(3)堆内存的对象什么时候被回收?
堆对象的生命周期是咋样的?什么时候被回收,回收前又如何流转?具体又是被如何回收?今天重点讲对象GC,看完这篇就全都明白了。
|
C++
析构造函数就是为了释放内存,就是在局部指针消失前释放内存,拷贝构造函数就是以构造函数为模块,在堆里面新开一块,同一个变量在堆里面的地址
本文讨论了C++中构造函数和析构函数的作用,特别是它们在管理动态内存分配和释放中的重要性,以及如何正确地实现拷贝构造函数以避免内存泄漏。
169 2
|
存储 安全 Java
JVM常见面试题(二):JVM是什么、由哪些部分组成、运行流程,JDK、JRE、JVM关系;程序计数器,堆,虚拟机栈,堆栈的区别是什么,方法区,直接内存
JVM常见面试题(二):JVM是什么、由哪些部分组成、运行流程是什么,JDK、JRE、JVM的联系与区别;什么是程序计数器,堆,虚拟机栈,栈内存溢出,堆栈的区别是什么,方法区,直接内存
JVM常见面试题(二):JVM是什么、由哪些部分组成、运行流程,JDK、JRE、JVM关系;程序计数器,堆,虚拟机栈,堆栈的区别是什么,方法区,直接内存
|
存储 程序员 编译器
堆和栈内存的区别是什么
【8月更文挑战第23天】堆和栈内存的区别是什么
1275 4