zoukankan      html  css  js  c++  java
  • 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是指的继承来的方法。

    
    
  • 相关阅读:
    redis 键命令
    redis 数据类型
    java向word写入数据
    Eclipse发布到tomcat提示java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener
    Unable to locate Spring NamespaceHandler for XMLschemanamespace http://dubbo.apache.org/schema/dubbo
    5.Dubbo之Spring XML配置
    6.Dubbo之XML配置详解。
    7.Dubbo之最佳实践
    RESTful API实践
    Jav程序执行Linux命令
  • 原文地址:https://www.cnblogs.com/kkrs/p/10789127.html
Copyright © 2011-2022 走看看