![移动App性能评测与优化](https://wfqqreader-1252317822.image.myqcloud.com/cover/107/840107/b_840107.jpg)
上QQ阅读APP看书,第一时间看更新
1.3.1 Dalvik Heap内部机制
为了弄清楚为什么DVM占着内存不释放,我们阅读了DVM分配内存部分的代码。位置在Android源码的dalvik/vm/alloc下,约255KB。分析的主要流程如下:
1)DVM使用mmap系统调用从系统分配大块内存作为Java Heap。根据系统机制,如果分类的内存尚未真正使用,就不计入PrivateDirty和Pss。例如图1-8所示,Heap Size/Alloc很多,但大部分是共享的,实际使用的较少。所以反映到PrivateDirty/Pss里的内存并不多。
![](https://epubservercos.yuewen.com/B6E540/5380295204741601/epubprivate/OEBPS/Images/figure_0031_0001.jpg?sign=1739463248-0nUg9LxmOzg2sbz31eXqrGjSQN47Llsp-0-14578b3399951a498fd874dadf68c1e8)
图1-8 共享内存较多的进程
2)新建对象之后,由于要向对应的地址写入数据,内核开始真正分配该地址对应的4KB物理内存页面。
Alloc.cpp中,从第176行起的代码如图1-9所示。
![](https://epubservercos.yuewen.com/B6E540/5380295204741601/epubprivate/OEBPS/Images/figure_0031_0002.jpg?sign=1739463248-iZm4hhw1YfZUSwvJHKF3o5V2xHoa8gHa-0-6095d2d0a30a6750f6a6aaee709e8699)
图1-9 DVM虚拟机分配内存的代码
3)运行一段时间后,开始垃圾回收(GC),有些对象被回收了,有些会一直存在,如图1-10所示。
![](https://epubservercos.yuewen.com/B6E540/5380295204741601/epubprivate/OEBPS/Images/figure_0032_0001.jpg?sign=1739463248-pfdXLFDty1FOydHoPMxDHVqAeKjnGqqY-0-45a06181457c2e27a2167a74d992845a)
图1-10 黑点表示的内存会被回收
4)在GC时,有可能会进行trim,即将空闲的物理页面释放回系统,表现为PrivateDirty/Pss下降。HeapSource.cpp中,第431行代码如图1-11所示。
![](https://epubservercos.yuewen.com/B6E540/5380295204741601/epubprivate/OEBPS/Images/figure_0032_0002.jpg?sign=1739463248-DUURoJFnalwFHiq3gqmpO3x832lQkcQJ-0-63d8f7cf7605069ddbcece351e161482)
图1-11 释放内存回系统的代码(一)
HeapSource.cpp中,第1304行代码如图1-12所示。
![](https://epubservercos.yuewen.com/B6E540/5380295204741601/epubprivate/OEBPS/Images/figure_0033_0001.jpg?sign=1739463248-6K5BgCz94FwTBPoKmiKbITIeT6WVwx3L-0-8ca70afc2aa371e4c1e2237232c1450a)
图1-12 释放内存回系统的代码(二)