博客
关于我
Android启动优化--AOP获取方法耗时
阅读量:294 次
发布时间:2019-03-03

本文共 1084 字,大约阅读时间需要 3 分钟。

启动优化--AOP获取方法耗时

AOP 的意思是面向切面编程,详见 Spring 中的 AOP,是一个意思。

 

背景

需要知道启动阶段各个方法耗时情况,常规操作是通过手动埋点的方式,这个方式代码的侵入性强,工作量大。

 

AOP介绍

Aspect Oriented Programming , 面向切面编程,优点如下。

(1)针对同一类问题的统一处理

(2)无侵入添加代码

 

AspectJ 的使用

这个是用来辅助实现AOP的。

(1)在项目的根目录下的 build.gradle 下面添加  classpath 'com.hujiang.aspectjx:gradle-android-plugin-aspectjx:2.0.0'  。如:

(2)在 app 目录下的 build.gradle 文件中,在 dependencies 添加  implementation 'org.aspectj:aspectjrt:1.8.+' 。

(3)在 app 目录下的 build.gradle 文件中,在该文件的最上面添加  apply plugin: 'android-aspectjx' 。如下:

相关概念:

 

@Aspectpublic class PerformanceAop {    @Around("call(* com.optimize.performance.PerformanceApp.**(..))")    public void getTime(ProceedingJoinPoint joinPoint) {        Signature signature = joinPoint.getSignature();        String name = signature.toShortString();        long time = System.currentTimeMillis();        try {            joinPoint.proceed();        } catch (Throwable throwable) {            throwable.printStackTrace();        }        LogUtils.i(name + " cost " + (System.currentTimeMillis() - time));    }}

结果如下:

 

优点:

(1)代码无侵入性,

(2)方便修改;

 

总结

(1)优雅获取方法耗时的方式;

(2)AOP的理解和使用

 

转载地址:http://aypm.baihongyu.com/

你可能感兴趣的文章
MySQL_属性、记录长度、设计范式、表关系
查看>>
MySQL_安全管理、表单传值、php操作
查看>>
POJ 2299 Ultra-QuickSort(树状数组+离散化+求逆序数)
查看>>
POJ 3468 A Simple Problem with Integers(线段树+区间更新)
查看>>
BugkuCTF web_31-40
查看>>
BUUCTF web WarmUp
查看>>
hcnp笔记
查看>>
python数据分析
查看>>
MySQL(四)数据库结构设计
查看>>
Vue(六)Vue中的计算属性和侦听器
查看>>
springmvc(1)架构执行流程
查看>>
JavaScript 函数作用域
查看>>
React props
查看>>
2021-05-03
查看>>
Mybatis-plus 常用注解
查看>>
HTML基本结构
查看>>
图(三):拓扑排序、关键路径
查看>>
centos的my.cnf文件在哪里
查看>>
mybatis 如何切割字符串 查询多个值
查看>>
算法初步 (排序, 散列, 贪心, 二分, two pointers)
查看>>