Kyrie66c 2022-06-19 22:55 采纳率: 80%
浏览 28
已结题

用AOP做功能增强怎么让集合循环输出一万次?为什么接收返回值再返回去只输出了一次?

img

img


让集合输出一万次的话代码怎么改?为什么接收数据再返回去也只能输出一次

  • 写回答

1条回答 默认 最新

  • it_hao528 2022-06-19 23:39
    关注

    AOP是对方法做了功能加强,相当于用代理的方式重写了原有方法,在调用原有方法时就会执行这里的方法,如果原有方法有返回值,那么这里对应方法需要设置返回值,如下:

        @Around("pt()")
        public Object runSpeed(ProceedingJoinPoint pjp) throws Throwable {
            // 记录程序当前执行(开始时间)
            long startTime = System.currentTimeMillis();
            // 业务执行方法
            Object ret = null;
            for (int i = 0; i < 10000; i++) {
                ret = pjp.proceed();
            }
            // 记录程序当前执行时间(结束时间)
            long endTime = System.currentTimeMillis();
            // 计算时间差
            long totalTime = endTime - startTime;
            // 输出信息
            System.out.println("执行万次消耗时间:" + totalTime + "ms");
            return ret;
        }
    

    可以查看proceed()方法源码可以看到,其有返回值是Object类型,所以这里使用Object类型,当调用加强的方法时,拿到的结果就是这里返回的ret,是只有一次的。要想打印输出每次原有方法的返回值,在循环里边打印就行了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 7月22日
  • 已采纳回答 7月14日
  • 创建了问题 6月19日

悬赏问题

  • ¥15 Python3.5 相关代码写作
  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)