AOP的基本使用

资源链接aspect.jar

优势:利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率

 以下是实现aop开发最基本的实现

1,在app中的build.gradle中添加一下代码(加粗部分):

apply plugin: 'com.android.application'
//Aop需要用自己的编译器进行编译
buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        classpath 'org.aspectj:aspectjtools:1.8.8'
        classpath 'org.aspectj:aspectjweaver:1.8.8'
    }
}
android {
    compileSdkVersion 26
    buildToolsVersion "26.0.2"
    defaultConfig {
        applicationId "com.richard.aop"
        minSdkVersion 15
        targetSdkVersion 26
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    compile 'com.android.support:appcompat-v7:26.+'
    compile 'com.android.support.constraint:constraint-layout:1.0.2'
    testCompile 'junit:junit:4.12'
    compile files('libs/aspectjrt.jar')
}

//以下代码是为了看aspect打印信息
import org.aspectj.bridge.IMessage
import org.aspectj.bridge.MessageHandler
import org.aspectj.tools.ajc.Main

final def log = project.logger
final def variants = project.android.applicationVariants

variants.all { variant ->
    if (!variant.buildType.isDebuggable()) {
        log.debug("Skipping non-debuggable build type '${variant.buildType.name}'.")
        return;
    }

    JavaCompile javaCompile = variant.javaCompile
    javaCompile.doLast {
        String[] args = ["-showWeaveInfo",
                         "-1.8",
                         "-inpath", javaCompile.destinationDir.toString(),
                         "-aspectpath", javaCompile.classpath.asPath,
                         "-d", javaCompile.destinationDir.toString(),
                         "-classpath", javaCompile.classpath.asPath,
                         "-bootclasspath", project.android.bootClasspath.join(File.pathSeparator)]
        log.debug "ajc args: " + Arrays.toString(args)

        MessageHandler handler = new MessageHandler(true);
        new Main().run(args, handler);
        for (IMessage message : handler.getMessages(null, true)) {
            switch (message.getKind()) {
                case IMessage.ABORT:
                case IMessage.ERROR:
                case IMessage.FAIL:
                    log.error message.message, message.thrown
                    break;
                case IMessage.WARNING:
                    log.warn message.message, message.thrown
                    break;
                case IMessage.INFO:
                    log.info message.message, message.thrown
                    break;
                case IMessage.DEBUG:
                    log.debug message.message, message.thrown
                    break;
            }
        }
    }
}

2.在activity_main布局文件中添加四个按钮,代码如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.richard.aop.MainActivity"
    android:orientation="vertical">

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="mShake"
        android:text="摇一摇" />
    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="mAudio"
        android:text="语音消息" />

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="mVideo"
        android:text="视频通话" />

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="saySomething"
        android:text="发表说说" />

</LinearLayout>

3,在java代码中处理四个按钮的点击事件

    /**
     * 摇一摇事件
     * @param view
     */
    @BehaviorTrace("摇一摇")
    public void mShake(View view) {

    }

    /**
     * 语音消息
     * @param view
     */
    @BehaviorTrace("语音消息")
    public void mAudio(View view) {

    }

    /**
     * 视频通话
     * @param view
     */
    @BehaviorTrace("视频通话")
    public void mVideo(View view) {

    }

    /**
     * 发表说说
     * @param view
     */
    @BehaviorTrace("发表说说")
    public void saySomething(View view) {


    }

4,定义一个注解类BehaviorTrace,如下所示:然后将这些注解用在每个按钮点击回调方法的上面,

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface BehaviorTrace {
    String value();
}

5,写一个切面类BehaviorTraceAspect:

/**
 * Created by Administrator on 2018/3/17 0017.
 */
@Aspect
public class BehaviorTraceAspect {
    public static final String TAG = "BehaviorTraceAspect";
    //定义切面的规则
    //就是将之前使用注解的地方加入到切面
    @Pointcut("execution(@com.richard.aop.annotation.BehaviorTrace * *(..))")
    public void methodAnnotionWithBahaviorTrace(){}


    //2.对进入切面的内容如何处理
    //advice
    //@Before()  在切入点之前运行
    //@After()   在切入点之后运行
    //@Around()  在切入点前后都运行
    @Around("methodAnnotionWithBahaviorTrace()")
    public Object weaveJoinPoint(ProceedingJoinPoint joinPoint) throws Throwable {
        MethodSignature signature  = (MethodSignature) joinPoint.getSignature();
        String className = signature.getDeclaringType().getSimpleName();
        String methodName = signature.getName();
        String funName = signature.getMethod().getAnnotation(BehaviorTrace.class).value();

        long begin = System.currentTimeMillis();//开始时间
        Object result = joinPoint.proceed();
        long end = System.currentTimeMillis();
        long duration = end - begin;
        Log.d("richard",String.format("功能名:%s,%s的%s方法执行了%d时间",funName,className,methodName,duration));
        return result;
    }
}


猜你喜欢

转载自blog.csdn.net/a1527238987/article/details/79660502
今日推荐