Android Aop日志

Android在许多情况下需要知道一些方法的耗时,然后对与这些耗时进行一些处理和优化。当然我们可以在方法的开头和结尾分别来打一行日志来解决这个问题。但是这个方式侵入性强,而且比较难以修改和删除这些日志,所以可以使用aop的方式进行输出日志,不仅可以让日志进行统一的管理,还比较方便修改。

 

首先需要导入在项目的build中增加 classpath 'com.hujiang.aspectjx:gradle-android-plugin-aspectjx:2.0.0',然后在app build中加入 apply plugin: 'android-aspectjx',就可以使用 org.aspectj:aspectjrt:1.8.+。

@Aspect
public class AppAop {

    @Around("call(* com.kkrs.basepage.MainActivity.**(..))")
    public void getTimeMainActivity(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));
    }

    @Around("execution(* com.kkrs.basepage.MainActivity.**(..))")
    public void getTimeMainActivity2(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));
    }


}              

 

注:里面的call是指的自定义的方法,execution是指的继承来的方法。

 

 

 

 

 

 

 

 

转载于:https://www.cnblogs.com/kkrs/p/10789127.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值