- 只关心函数调用,函数执行后参数变化情况
- 可以快速定位参数,输出是文本格式,可以用任意文本编辑器打开
- 可以脱出很多有用有价值的信息,帮助快速定位
- 同时记录了所在的内存地址,方便使用traceWrite/Read 跟踪定位
- 现版本的加了函数执行计数,在一个函数多次执行的时候,可以快速定位轮数
- java不是很熟练,有不合理的地方,请自行修改源码
- 参数注释说明( 类名下
- 函数调用过滤,防止函数调用次数过多,导致日志太多,trace效率极低
new TraceFunction(emulator, module, savePath);
data:image/s3,"s3://crabby-images/12e12/12e129cd129e8ee151bf3030a064d033304f2e20" alt="img_4.png"
data:image/s3,"s3://crabby-images/eae0e/eae0e2e2e96077f432c550cd88e3e3b99809772d" alt="img_5.png"
data:image/s3,"s3://crabby-images/3be67/3be672d0bb22bb407b0bb1d4c7f96874bdb28752" alt="img_1.png"
data:image/s3,"s3://crabby-images/c4f27/c4f27316ba92830d5ed07270f05e997b693dba3a" alt="img_2.png"
data:image/s3,"s3://crabby-images/56b13/56b13a5f74cf5571953c2b27bf50fe43764edd7d" alt="img_3.png"
data:image/s3,"s3://crabby-images/32e46/32e4605646ef157e4369234dfde0cd64f3fdfd39" alt="img.png"
======== =========================== 函数分割线
执行函数的指令地址 sub:函数地址 [call count: 调用次数]
-------- --------------------------- 函数入参
内存地址
======== =========================== 函数分割线
执行函数的指令地址 call sub:返回的函数地址
-------- --------------------------- 函数反参 (也就是入参)
内存地址
-------- --------------------------- retValue (函数返回值)