这是我踏入学习JUC的第一步
至于JUC什么,做个简单介绍,其实就是jdk5.0新发布的一个java工具包,涵盖多线程并发编程的一些工具类,也就是
java.util.concurrent
直接开始学习TimeUnit吧,它可以实现类似于sleep的延时功能,而且比sleep的功能强大好多,内置函数更加适用。
打开它的源码看看,如下反编译。
发现它是一个枚举类型,而且也是JUC包内唯一 一个枚举类型
我们发现它内部实现了一些枚举,这些枚举实现的主要目的是方便我们实现各个不同单位的延时,比如实现以秒为单位的延时,以毫秒,纳秒。。
总共有如下几种类型
/**
* 纳秒
*/
NANOSECONDS(TimeUnit.NANO_SCALE),
/**
* 微秒
*/
MICROSECONDS(TimeUnit.MICRO_SCALE),
/**
* 毫秒
*/
MILLISECONDS(TimeUnit.MILLI_SCALE),
/**
* 秒
*/
SECONDS(TimeUnit.SECOND_SCALE),
/**
* 分
* @since 1.6
*/
MINUTES(TimeUnit.MINUTE_SCALE),
/**
* 时
* @since 1.6
*/
HOURS(TimeUnit.HOUR_SCALE),
/**
* 天
* @since 1.6
*/
DAYS(TimeUnit.DAY_SCALE);
1、假如我们实现以秒为单位的延时;如下
// 每隔3秒 输出一次 i
for(int i=0;i<10;++i) {
System.out.println(i);
TimeUnit.SECONDS.sleep(3);
}
2、TimeUnit还给我们提供了它内置的转换函数convert(数值,该数值的TimeUnit类型),如下例子
// 首先1的单位是天。相当于把1天时间刻度转换为以秒为单位的时间刻度
long convert = TimeUnit.SECONDS.convert(1, TimeUnit.DAYS);
System.out.println(convert);
得出的类型是long的原因我想你们也大概知道,就要是怕时间刻度相差太大,一般的int存储发生溢出的可能!
3、long类型转相应的时间刻度函数
4、超时控制函数 timedJoin
public void timedJoin(Thread thread, long timeout)
throws InterruptedException {
if (timeout > 0) {
long ms = toMillis(timeout);
int ns = excessNanos(timeout, ms);
thread.join(ms, ns);
}
}
这个以后再做讨论
其它的倒是没有什么,目前就上面的sleep和convert方法重要点,同时我们还可以通过convert方法快速获得我们以后的时间,如下
public static void main(String[] args){
// 时间格式 年--月--日
SimpleDateFormat Sformat = new SimpleDateFormat("yyyy-MM-dd");
// 先打印今天的日期
System.out.println("今天的日期: "+Sformat.format(System.currentTimeMillis()));
// 将 2天 转换为 毫秒 单位的数值
long convert = TimeUnit.MILLISECONDS.convert(2, TimeUnit.DAYS);
// 当前日期 + 所给定的毫秒数 = 未来的日期 ,最终转换为 ,年-月-日 的字符串格式
String futureDate = Sformat.format(System.currentTimeMillis() + convert);
// 输出结果
System.out.println("未来的日期: "+futureDate);
}
输出结果
TimeUnit 就到这里了~~~~