Spring Boot源码如何实现StopWatch优雅统计耗时


今天小编给大家分享一下SpringBoot源码如何实现StopWatch优雅统计耗时的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。昨天,一位球友问我能不能给他解释一下 @SpringBootApplication 注解是什么意思,还有 Spring Boot 的运行原理,于是我就带着他扒拉了一下这个注解的源码,还有 SpringApplication 类的 run() 方法的源码,一下子他就明白了。你别说,看源码的过程还真的是挺有趣,这不,我就发现了一个有意思的点。Spring Boot 是用 StopWatch 来统计耗时的,而通常情况下,我们会用 System.currentTimeMillis() 来统计耗时,对吧?编程喵????开源项目里就有这样一段代码,在处理统一日志处理切面的时候。对比之下,我们就能发现,JDK 提供的 System.currentTimeMillis() 没有 Spring 提供的 StopWatch 简洁、清晰。尤其是在多任务的情况下,StopWatch 简直好用到爆????!看到没,是不是很简单?先 new 一个 StopWatch 对象再 start 开始计时然后 stop 停止计时最后通过 sw.getLastTaskTimeMillis() 得出时间差如果换成 System.currentTimeMillis() 就要了老命,先得声明好几个 long 型的局部变量,然后要第二个减第一个,第三个减第二个,稍微粗心一点(尤其是 CV 大法)时,很容易搞错。除了可以通过局部时间,还可以通过 sw.getTotalTimeSeconds() 获取总的耗时。任务1耗时:1002ms.
任务2耗时:1105ms.
任务数量:2,总耗时:2.107820109s.另外,StopWatch 还提供了一个 sw.prettyPrint() 方法供打印出漂亮的格式化结果:StopWatch ‘沉默王二是傻 X’: running time = 2108529351 ns
———————————————
ns % Task name
———————————————
1004338467 048% 任务1
1104190884 052% 任务2有耗时,有占用百分比,还有任务名,非常清晰。除了 Spring,hutool 工具库和 Apache common 工具包都提供了各自的 StopWatch。查看 hutool 工具库中的 StopWatch 源码可以得出,该类其实就来自 Spring 的 StopWatch.java,用法也完全一致。这说明 hutool 的作者也认为 Spring 的 StopWatch 写得好,哈哈哈????。使用 Beyond compare 比较后也能得出,两者除了一个中文注释,一个英文注释,代码几乎一样。setKeepTaskList 方法有比较大的不同。那也就是说,如果你的项目中没有使用 Spring 全家桶,只用了 hutool 工具包,那就可以使用 hutool 的 StopWatch 来代替 System.currentTimeMillis()。通过分析 StopWatch 的 stop 方法源码:其实可以发现,StopWatch 的内部是通过 System.nanoTime() 来计时的,本质上和 System.currentTimeMillis() 差别并不大。nanoTime 比 currentTimeMillis 的粒度更细,前者是以纳秒为单位,后者是以毫秒为单位。注意两者都是 native 方法,也就是说,值的粒度其实取决于底层的操作系统。看到这,大家可能会恍然大悟,StopWatch 不过是披着一层外衣的 System.currentTimeMillis() 嘛?但妙就妙在,这层外衣足够的漂亮,足够的优雅。StopWatch 可以记录每个子任务的名称,以及按格式化打印结果,尤其是针对多任务统计时更友好一点。当然了,除了选择 Spring 和 hutool 的 StopWatch,Apache commons-lang3 的 StopWatch 也是一个不错的可选项,更加灵活多变。其他两个都是通过 new 来免费云主机域名创建 StopWatch 对象,commons-lang3 还可以通过 createStarted(创建并立即启动)、create(创建)来完成。还可以调用 suspend 方法暂停计时、resume 方法恢复计时、reset 重新计时。以上就是“SpringBoot源码如何实现StopWatch优雅统计耗时”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注百云主机行业资讯频道。

相关推荐: WPF如何使用DrawingContext实现二维绘图

这篇文章主要讲解了“WPF如何使用DrawingContext实现二维绘图”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“WPF如何使用DrawingContext实现二维绘图”吧!DrawingContext比…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 03/25 07:42
下一篇 03/25 07:42

相关推荐