让集合输出一万次的话代码怎么改?为什么接收数据再返回去也只能输出一次
用AOP做功能增强怎么让集合循环输出一万次?为什么接收返回值再返回去只输出了一次?
让集合输出一万次的话代码怎么改?为什么接收数据再返回去也只能输出一次
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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,是只有一次的。要想打印输出每次原有方法的返回值,在循环里边打印就行了。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
- ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
- ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
- ¥30 关于<main>标签页面跳转的问题
- ¥80 部署运行web自动化项目
- ¥15 腾讯云如何建立同一个项目中物模型之间的联系
- ¥30 VMware 云桌面水印如何添加
- ¥15 用ns3仿真出5G核心网网元
- ¥15 matlab答疑 关于海上风电的爬坡事件检测
- ¥88 python部署量化回测异常问题