android studio 分析 hprof,移动学习 AndroidStudio内存优化分析—hprof文件分析

1、移动学习在主界面时按如下顺序点击:

03a6a779a9f7c261f659ca1867d502bf.png

2、其实和 android内存分析 outOfMemoryError错误定位及分析策略(非显示图片造成) 中用eclipse前7步的设置一样,只不过这个速度更快一些,更方便一些(eclipse ddms模式下卡的要死要死~~~~)

0ad388ec2d5f2f5f54962d9041c5dea4.png

54a453c346a0a0e57bb264e8e2c8d625.png

5dda420a0022a5a694ccaf32c4da28ee.png

4、按Shallow Heap降序排列后,如上图所示,其中 Shallow Heap代表:对象本身占用内存的大小,不包含其引用的对象。Retain Heap代表:如果这个对象被释放掉,那会因为该对象的释放而减少引用进而被释放的所有的对象大小。直观的说就是MainNewActivity占了312字节的内存,如果被释放掉的话会释放大于等于2888字节的内存。

6df5adfdd12b14ffe6914107f05f6f45.png

5、在MainNewActivity右键->List Objects会出现两个选项:with outgoing references 和 with incoming references

with outgoing references是指 被该对象引用的对象 (这个对象持有了哪个类或方法)

with incoming references是指引用到该对象的对象(哪个对象或类持有了该方法)

点击with outgoing references后如图:

794b5c8be5896f41521fe534232320a9.png

6、显示出MainNewActivity所持有的所有成员变量,activityInfo的所有信息等等,点击其中的termEnd右键with incoming references,列出所有持有该对象的对象:

59e06987bd47daf94b16fabac5501eaf.png

7、即可看到LoadActivity、SettingsActivity、LoginActivity都持有该变量(该变量写在了BaseActivity里),所以很容易造成内存泄漏。改!

8、GC Roots:调用该对象的跟节点,例子如图:

a3f24b9ae7aa499af4c347f164ae146a.png

9、如果在object4上右键 path to GCRoot -> exclude all phantom/weak/soft etc. references(去除所有的虚引用,弱引用,软引用) 就会得到调用该类的跟节点,例如:

9e02a41348804e1d511ec3e4bc515b7b.png

b8867de2219dc583a36d20bd32d7d1a7.png

10、可以看出实在DBManagerHelper中实例化sqliteOpenHelper时初次调用了sqliteOpenHelper。此方法在查询变量在哪里最初调用非常好使。

暂时先写这些~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值