标签:
就目前来说,即使标注为GMT(无论是文件说明,或者是API的日期时间字符串描述),实际上谈到时间指的是UTC时间。
秒的单位定义是基于TAI,也就是铯原子辐射振动次数。
epoch为某个特定时代的开始,时间轴上某一瞬间。
UTC考虑了地球自转越来越慢而有闰秒修正,确保UTC与UT相差不会超过0.9秒。
Unix时间是1970年1月1日00:00:00为起点而经过的秒数,不考虑闰秒。
如果想要取得系统时间,方法之一是使用System.currentTimeMillis()方法,返回的是long类型整数。如:
import java.util.*;
import static java.lang.System.*;
public class DateDemo {
public static void main(String[] args) {
Date date1 = new Date(currentTimeMillis());
Date date2 = new Date();
out.println(date1.getTime());
out.println(date2.getTime());
}
}
Date有两个构造函数可以使用,一个可使用epoch毫秒数构建,另一个为无自变量构造函数,内部亦是使用System.currentTimeMillis()取得毫秒数,调用getTime()可取得内部保存的epoch毫秒数值。范例执行结果如下:
DateFormat是个抽象类,其操作类是java.text.SimpleDateFormat,你可以直接构建SimpleDateFormat实例,或是使用DateFormat的getDateInstance()、getTimeInstance()、getDateTimeInstance等静态方法,用较简便方式按不同需求取得SimpleDateFormat实例。
直接构建SimpleDateFormat的好处是,可使用模式字符串自定义格式。
SimpleDateFormat还有个parse()方法,可以按构建SimpleDateFormat时指定的格式,将指定的字符串剖析为Date实例。如:
import java.util.*;
import java.text.*;
public class HowOld {
public static void main(String[] args) throws Exception {
System.out.print("輸入出生年月日(yyyy-mm-dd):");
DateFormat dateFormat = new SimpleDateFormat("yyyy-mm-dd");
Date birthDate = dateFormat.parse(new Scanner(System.in).nextLine());
Date currentDate = new Date();
long life = currentDate.getTime() - birthDate.getTime();
System.out.println("你今年的歲數為:" +
(life / (365 * 24 * 60 * 60 * 1000L)));
}
}
执行结果如图:
Date现在建议作为时间轴上的瞬间代表,要格式化时间日期则通过DateFormat,如果想要取得某个时间日期信息,或者是对时间日期进行操作,可以使用Calendar实例。如:
Calendar calendar = Calendar.getInstance();
Calendar是个抽象类,java.util.GregorianCalendar是其子类,操作了儒略历与格里高利历的混合历,通过Calendar的getInstance()取得的Calendar实例,默认就是取得GregorianCalendar实例。如:
out.println(calendar.get(Calendar.YEAR));
out.println(calendar.get(Calendar.MONTH));
out.println(calendar.get(Calendar.DATE));
若想取得默认时区信息,可以使用java.util.TimeZone的getDefault()方法。如:
import static java.lang.System.out;
import java.util.TimeZone;
public class TimeZoneDemo {
public static void main(String[] args) {
TimeZone timeZone = TimeZone.getDefault();
out.println(timeZone.getDisplayName());
out.println("\t時區ID:" + timeZone.getID());
out.println("\t日光節約時數:" + timeZone.getDSTSavings());
out.println("\tUTC 偏移毫秒數:" + timeZone.getRawOffset());
}
}
执行结果如图:
可以使用Instance的静态方法now()取得代表Java epoch毫秒数。在取得Instance实例后,可以使用plusSeconds()、plusMills()、plusNanos()、minusSeconds()、minusMills()、minusNanos()来做时间轴上的运算,Instance实例本身不会变动,这些操作都会返回新的Instance实例,代表运算后的瞬时。
如果取得了Date实例,而想要改用Instance,则可以调用Date市里的toInstance()方法来取得,如果有个Instance实例,可以使用Date的静态方法from()转为Date。
LocalDateTime、LocalDate、LocalTime等类名称开头为Local,表示它们都只是对时间的描述,并没有时区信息。
对于时间计量,新时间与日期API以类Duration来定义,可用于计量天、时、分、秒的时间差,精度调整可以达纳秒等级,而秒的最大值可以是long类型保存值。对于年、月、星期、日的时间差,则使用Period类定义。如:
import java.time.*;
import java.util.Scanner;
import static java.lang.System.out;
public class HowOld2 {
public static void main(String[] args) {
out.print("輸入出生年月日(yyyy-mm-dd):");
LocalDate birth = LocalDate.parse(new Scanner(System.in).nextLine());
LocalDate now = LocalDate.now();
Period period = Period.between(birth, now);
out.printf("你活了 %d 年 %d 月 %d 日%n",
period.getYears(), period.getMonths(), period.getDays());
}
}
执行结果如图:
学习了13.3.3 对时间的运算后,发现Period与Duration很相似,不清楚二者的具体区别在哪。
通过学习教材与上网查资料,总结出以下差别:
Period是日期差,between()方法只接受LocalDate,不表示比“日”更小的单位,然而Duration是时间差,
between()可以接受Temporal操作对象,也就是说可以用LocalDate、LocalTime、LocalDateTime来计算
Duration,不表示比“天”更大的单位。
对书上p435页代码片段(如下)中的“Calender calender = (Calender) begin.clone()”不太理解。
public static long yearsBetween(Calendar begin, Calendar end) {
Calendar calendar = (Calendar) begin.clone(); long years = 0;
while (calendar.before(end)) {
calendar.add(Calendar.YEAR, 1);
years++;
}
return years - 1;
}
public static long daysBetween(Calendar begin, Calendar end) {
Calendar calendar = (Calendar) begin.clone();
long days = 0;
while (calendar.before(end)) {
calendar.add(Calendar.DATE, 1);
days++;
}
return days - 1;
}
通过看书上对代码范例的分析,得到如下解释:
如果在Calendar实例上进行add()之类的操作,则会修改Calendar实例本身,为了避免调用yearsBetween()、
daysBetween()之后传入的Calendar自变量被修改,两个方法中都对第一个自变量进行了clone()复制对象的动
作。
程序运行结果如图:
本周学习了第十三章,我了解了一些时间、日期的历史问题,并且知道了应该如何使用Java程序来处理时间日期,我认为新时间日期处理API中最重要的,就是清楚地将机器对时间的概念与人类对时间的概念区隔开来,让机器与人类对时间概念的界线变得分明。这周的学习任务只有一章,因此我有更多的时间来仔细学习这章的内容,把不懂的知识点一一弄清楚明白,我认为这样的学习进度比较合适,不用为了按时完成任务而放弃细究一些不会的问题。
代码行数(新增/累积) | 博客量(新增/累积) | 学习时间(新增/累积) | 重要成长 | |
---|---|---|---|---|
目标 | 4500行 | 30篇 | 350小时 | 能将java运用自如 |
第一周 | 150/150 | 2/2 | 15/15 | 学习了与java相关的基础知识 |
第二周 | 200/350 | 1/3 | 20/35 |
学习了java的基本语法 |
第三周 | 450/800 | 1/4 | 25/60 |
学习了对象和封装的相关知识 |
第四周 | 687/ 1487 | 1/5 | 30/90 |
学习了继承与接口的相关知识 |
第五周 | 803/2290 | 1/6 | 30/120 |
学习了异常处理以及Collection与Map的相关知识 |
第六周 | 910/3200 | 2/8 | 40/160 |
学习了输入、输出和线程的相关知识 |
第七周 | 350/3550 | 2/10 | 30/190 |
学习了时间与日期的相关知识 |
标签:
原文地址:http://www.cnblogs.com/sjy519/p/5396950.html