温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Springboot之怎么统计代码执行耗时时间

发布时间:2023-03-16 16:29:56 来源:亿速云 阅读:159 作者:iii 栏目:开发技术

这篇文章主要介绍“Springboot之怎么统计代码执行耗时时间”,在日常操作中,相信很多人在Springboot之怎么统计代码执行耗时时间问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Springboot之怎么统计代码执行耗时时间”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

    开始  System.currentTimeMillis()  减去  结束  System.currentTimeMillis()  等于  耗时   

    其实我个人感觉OK的,就这样就蛮好的,很多项目都是这样用的。

    简简单单的挺好。

    Springboot之怎么统计代码执行耗时时间

    正文

    ① StopWatch

    第一种玩法,spring util 里面提供的 StopWatch

    示例代码:

    StopWatch stopWatch = new StopWatch();
    stopWatch.start();
    //doInsert();
    //执行业务等
    stopWatch.stop();
    System.out.println(stopWatch.getTotalTimeMillis());

    效果: 

    Springboot之怎么统计代码执行耗时时间

    ②  System.nanoTime()

    第二种玩法   System.nanoTime()

    先不着急看怎么用, 我们看完第一种 StopWatch 的时候, 有没有小伙伴的思维散发够的,想着这spring 封装的统计耗时,自己是怎么实现的?

    题外话:

    一定要养成这种散发的思维, 很多兄弟朋友都跟我反馈过一些话题,就是说,项目里面没啥东西可学。 

    其实,这个很正常, 工作过程不是教导过程,你要自己有 纵向 挖掘 横向 散发的 学习思维。 

    直接点StopWatch  的源码看一眼, 哦,原理是用的  System.nanoTime() :

    Springboot之怎么统计代码执行耗时时间

     System.nanoTime() 代码使用示例 :

            long startTime = System.nanoTime();
            doInsert();
            //执行业务
            long endTime = System.nanoTime();
            System.out.println((endTime - startTime));

    效果 :

    Springboot之怎么统计代码执行耗时时间

    ③ new Date ()

    第三种玩法 ,平时偶尔也看到别人这么写 new Date 

    示例代码:

            Date startDate = new Date();
           // doInsert();
           //执行业务等
            Date endDate = new Date();
            System.out.println((endDate.getTime() - startDate.getTime()));

    效果:

    Springboot之怎么统计代码执行耗时时间

    ④  System.currentTimeMillis() 

    省略

    ps: StopWatch 其实不仅仅是封了一下耗时统计,这样也太。。了  。

    里面其实封装了蛮多其他关于时间统计的函数(感兴趣的可以单独去研究研究,特别是参考作者的封装思路 ):

    • void start(“任务名称”):开始一个任务名称的计时

    • void stop():停止当前任务的计时

    • boolean isRunning():是否正在计时某任务

    • long getTotalTimeMillis():所有任务的总体执行时间(毫秒单位)

    • double getTotalTimeSeconds():所有任务的总时间(以秒为单位)

    • long getLastTaskTimeMillis():上一个任务的耗时(毫秒单位)

    • int getTaskCount():定时任务的数量

    • String prettyPrint():优美地打印所有任务的详细耗时情况

    • StopWatch.TaskInfo[] getTaskInfo():包含任务名称和任务耗时的实体类数组

    到此,关于“Springboot之怎么统计代码执行耗时时间”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI