IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> 【无标题】 -> 正文阅读

[移动开发]【无标题】

AOP简单应用

项目的gradle里配置:
classpath “com.hujiang.aspectjx:gradle-android-plugin-aspectjx:2.0.8”

app的gradle里配置:
apply plugin: ‘com.hujiang.android-aspectjx’
dependencies{
implementation ‘org.aspectj:aspectjrt:1.8.+’
}

写一个简单且经典的应用场景,计算指定方法的执行时间:

写一个简单的类和方法:
package com.example.myapplication

import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        getTime()
    }

    public fun getTime(){
        Thread.sleep(3000)
    }
}`

现在计算一下getTime()这个方法的执行时间
再创建一个计算时间的类:

package com.example.myapplication;

import android.os.SystemClock;
import android.util.Log;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;

@Aspect
public class TimeAspect {
/**
这里@Pointcut里面可以写注解或者方法
 第一个*所在的位置表示的是返回值,*表示的是任意的返回值,
     .. 表示的是任意类型、任意个数的参数
     * 表示的是通配
    @Pointcut("execution(@ExecuteTime * * (..))")
    @Pointcut("execution(* getTime(..))")
    @Pointcut("execution(* com.example.myapplication.MainActivity.getTime(..))")
*/
    @Pointcut("execution(* com.example.myapplication.MainActivity.getTime(..))")
    public void Methoddd(){}//这个方法名可以随便写,但是要和下面的@Around的参数一直

//proceedingJoinPoint
    @Around("Methoddd()")
    public void callGetTime(ProceedingJoinPoint proceedingJoinPoint){
        long startTime = System.currentTimeMillis();

        try {
//如果要用@Arouund注解, 一定要记得写这一行代码,不然被计算的方法不会被执行
            proceedingJoinPoint.proceed();
        } catch (Throwable throwable) {
            throwable.printStackTrace();
        }

        long endTime = System.currentTimeMillis();
        Log.i("---+++", "callGetTime: time == "+(endTime - startTime));

    }

}

执行结果:

2022-01-28 17:30:30.812 23576-23576/com.example.myapplication I/---+++: callGetTime: time == 3000

这些都会编译时动态插入代码,所以不需要修改我们正常的MainActivity的代码

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-01-29 23:11:58  更:2022-01-29 23:13:20 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 12:54:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码