Thread.sleep(500); // 模拟耗费的时间
}
}
代码不用我说,项目中很常见,现在的问题是APP启动加载很慢, 那么如何精准的查询到具体耗时的方法?
long startTime = System.currentTimeMillis();
initBugly();
Log.d(“lybj”, “initBugly()方法耗时:”+ (System.currentTimeMillis() - startTime));
long startTime = System.currentTimeMillis();
initBaiduMap();
Log.d(“lybj”, “initBaiduMap()方法耗时:”+ (System.currentTimeMillis() - startTime));
…
这样可以吗?当然不行,耦合性太大,每一个方法都加,那么测试完了,删除代码也是个体力活,一不小心删错一个,就会造成灾难性的问题,在实际项目中,比如中石油的一些项目,就会采用 AOP 的方式来测量方法的耗费时长。
4.1 AOP
AOP : Aspect Oriented Programming的缩写,意为:面向切面编程
优点:
-
针对同一问题的统一处理
-
无侵入添加代码
这里我们使用的是Aspectj
4.2 Aspectj 的使用
1.添加依赖
<