Thread.sleep还是TimeUnit.SECONDS.sleep

简介:

刚看到TimeUnit.SECONDS.sleep()方法时觉得挺奇怪的,这里怎么也提供sleep方法?

1
2
3
4
5
6
7
public  void  sleep( long  timeout)  throws  InterruptedException {
     if  (timeout >  0 ) {
         long  ms = toMillis(timeout);
         int  ns = excessNanos(timeout, ms);
         Thread.sleep(ms, ns);
     }
}

结果一看源码,原来是对Thread.sleep方法的包装,实现是一样的,只是多了时间单位转换和验证,然而TimeUnit枚举成员的方法却提供更好的可读性,这可能就是当初创建TimeUnit时提供sleep方法的原因吧,大家都知道sleep方法很常用,但经常要使用一个常量保存sleep的时间,比如3秒钟,我们代码通常会这样写:

1
private  final  int  SLEEP_TIME =  3  1000 //3 seconds

因为Thread.sleep方法参数接受的毫秒单位的数值,比较下面代码就知道TimeUnit枚举成员的sleep方法更优雅:

1
2
3
4
5
6
TimeUnit.MILLISECONDS.sleep( 10 );
TimeUnit.SECONDS.sleep( 10 );
TimeUnit.MINUTES.sleep( 10 );
Thread.sleep( 10 );
Thread.sleep( 10 * 1000 );
Thread.sleep( 10 * 60 * 1000 );

但使用TimeUnit枚举成员的sleep方法会不会带来性能损失了,毕竟增加了函数调用开销?

测试测试吧:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import  java.util.concurrent.TimeUnit;
public  class  TestSleep {
     public  static  void  main(String[] args)  throws  InterruptedException {       
         sleepByTimeunit( 10000 );
                                                                                                               
         sleepByThread( 10000 );      
     }
     private  static  void  sleepByTimeunit( int  sleepTimes)  throws  InterruptedException {
         long  start = System.currentTimeMillis();
                                                                                                               
         for ( int  i= 0 ; i<sleepTimes; i++){
             TimeUnit.MILLISECONDS.sleep( 10 );
         }
                                                                                                               
         long  end = System.currentTimeMillis();
                                                                                                               
         System.out.println( "Total time consumed by TimeUnit.MILLISECONDS.sleep : "  + (end - start));
     }
                                                                                                           
     private  static  void  sleepByThread( int  sleepTimes)  throws  InterruptedException {
         long  start = System.currentTimeMillis();
                                                                                                               
         for ( int  i= 0 ; i<sleepTimes; i++){
             Thread.sleep( 10 );
         }
                                                                                                               
         long  end = System.currentTimeMillis();
                                                                                                               
         System.out.println( "Total time consumed by Thread.sleep : "  + (end - start));
     }
}

两次测试结果(Win7+4G+JDK7 测试期间计算资源充足):

1
2
3
4
5
6
Total time consumed by TimeUnit.MILLISECONDS.sleep :  100068
Total time consumed by Thread.sleep :  100134
Difference : -- - 66
Total time consumed by TimeUnit.MILLISECONDS.sleep :  100222
Total time consumed by Thread.sleep :  100077
Difference : -- + 145

从结果可以看出10000次调用差异很小,甚至一次更快,不排除JVM进行了优化,如果忽略性能方面考虑,从可读性方面建议使用TimeUnit枚举成员的sleep方法。


另外TimeUnit是枚举实现一个很好的实例,Doug Lea太神了,佩服得五体投地!


     本文转自sarchitect 51CTO博客,原文链接http://blog.51cto.com/stevex/1285767:,如需转载请自行联系原作者




相关文章
|
缓存 NoSQL Java
SpringBoot实现缓存预热的几种常用方案
SpringBoot实现缓存预热的几种常用方案
|
缓存 Java Go
解决Spring Data JPA查询存在缓存问题及解决方案
解决Spring Data JPA查询存在缓存问题及解决方案
1099 0
|
Java Apache Spring
springboot如何导出Excel某个表的表字段以及字段类型
springboot如何导出Excel某个表的表字段以及字段类型
357 0
|
消息中间件 数据安全/隐私保护
RabbitMQ 清除全部队列及消息
安装RabbitMQ后可访问:http://{rabbitmq安装IP}:15672使用(默认的是帐号guest,密码guest。此账号只能在安装RabbitMQ的机器上登录,无法远程访问登录。) 远程访问登录,可以使用自己创建的帐号,给与对应的管理员权限即可。
1439 0
|
10月前
|
安全 Java 数据库连接
gbase8a JDBC常用特性-Kerberos认证方式连接
JDBC常用特性-Kerberos认证方式连接
|
10月前
|
机器学习/深度学习 人工智能 算法
【AI系统】模型压缩基本介绍
模型压缩旨在通过减少存储空间、降低计算量和提高计算效率,降低模型部署成本,同时保持模型性能。主要技术包括模型量化、参数剪枝、知识蒸馏和低秩分解,广泛应用于移动设备、物联网、在线服务系统、大模型及自动驾驶等领域。
564 4
【AI系统】模型压缩基本介绍
|
10月前
|
IDE iOS开发 Python
小白如何开始使用通义灵码(含安装IDE、安装灵码插件)
PyCharm 和 IntelliJ IDEA 下载安装及通义灵码插件下载安装说明
8900 9
|
缓存 监控 NoSQL
|
安全 网络安全 数据安全/隐私保护
网络攻防演练需要注意哪些
【8月更文挑战第14天】
515 1
|
监控 数据可视化 项目管理
三角方式是什么?如何在项目管理中应用
在项目管理领域,三角方式(Project Management Triangle)是最经典的方法之一,强调项目成功的三大关键要素:范围、时间和成本。这三者相互关联,调整其中之一将影响其他两者。项目经理需在三者间找到平衡,以确保项目顺利进行。本文详细探讨了三角方式的概述、实际应用、执行步骤及案例分析,帮助项目经理更好地理解和运用这一模型,提高项目管理效率。通过合理应用三角方式,项目经理可在面对变化和挑战时,确保项目按时、按预算和高质量完成。
268 0