OOM内存溢出
Android中导致OOM的原因主要可以划分为以下几个类型:
动态内存分配监听
记录程序执行过程中的动态内存分配,当发生OOM或者发生性能问题时,就能够分析记录信息掌握内存使用情况。如:是否存在内存泄露、内存抖动、大对象等问题。
对象创建记录
ObjectAlloc|时间线程对象类型对象大小对象ID(TAG) 哪里创建(堆栈信息)
案例:
ObjectAlloc|TIME:1614847619390 THREAD:Thread-2 Class:Lcom/vance/jvmti/vance; Size:16 TAG:12777 Lcom/vance/jvmti/MainActivity$1;#run
对象回收记录
ObjectFree|TIME:1614847619545 TAG:12778
Application Performance Monitor (APM)应用性能监测软件
https://docs.oracle.com/javase/7/docs/platform/jvmti/jvmti.html
Java虚拟机工具接口,它可以监控 JVM 内部事件的执行,包括内存申请、线程创建、类加载、GC 信息、方法执行等;也可以控制 JVM 的某些行为。
https://source.android.google.cn/devices/tech/dalvik/art-ti#jvmti
日志方案记录
1、对产生的日志使用IO写入文件
突破DEBUG限制1
一般的在Android中使用Jvmti会使用Debug.attachJvmtiAgent来让虚拟机动态加载一个Jvmti Agent ,然后运行中能够触发JVM源生线程Attach Listener来执行这个Agen module的回调函数。
Debug.attachJvmtiAgent最后会调用到VMDebug.attachAgent中,VMDebug.attachAgent最终会调用到VMDebug_nativeAttachAgent中。
release启动时是关闭调试信息的,所以需要在调用VMDebug_nativeAttachAgent前开启调试能力。参考美团的方案可以调用SetJdwpAllowed来开启调试功能。
突破DEBUG限制2
完成了第一步操作之后,我们运行程序将得到以下错误:
根据日志信息很明显,在加载Agent的Agent_OnAttach函数要获取jvmti_env时候需要使用
ART_TI_VERSION_1_2(0x70010200)这个verison来获取,而不能用JVMTI_VERSION_1_2 (0x30010200)。