北大青鸟java培训:Java中的时间处理?

Python017

北大青鸟java培训:Java中的时间处理?,第1张

在Java中,如何获取不同时区的当前时间?你知道这道题的正确答案应该如何回答吗?背后的原理又是什么呢?然后,紧接着,我又提出了以下问题:为什么以下代码无法得到美国时间。

(在东八区的计算机上)接下来,java课程培训机构http://www.kmbdqn.cn/就围绕这两个问题,来带领读者一起学习一下哪些和Java中的时间有关的概念。

时区前面提到了时区,可能很多读者不知道什么是时区,先来简单介绍一下。

时区是地球上的区域使用同一个时间定义。

以前,人们通过观察太阳的位置(时角)决定时间,这就使得不同经度的地方的时间有所不同(地方时)。

1863年,首次使用时区的概念。

时区通过设立一个区域的标准时间部分地解决了这个问题。

世界各个国家位于地球不同位置上,因此不同国家,特别是东西跨度大的国家日出、日落时间必定有所偏差。

这些偏差就是所谓的时差。

为了照顾到各地区的使用方便,又使其他地方的人容易将本地的时间换算到别的地方时间上去。

有关国际会议决定将地球表面按经线从东到西,划成一个个区域,并且规定相邻区域的时间相差1小时。

在同一区域内的东端和西端的人看到太阳升起的时间最多相差不过1小时。

当人们跨过一个区域,就将自己的时钟校正1小时(向西减1小时,向东加1小时)接下来,本文就围绕这两个问题,来带领读者一起学习一下哪些和Java中的时间有关的概念。

时区前面提到了时区,可能很多读者不知道什么是时区,先来简单介绍一下。

时区是地球上的区域使用同一个时间定义。

以前,人们通过观察太阳的位置(时角)决定时间,这就使得不同经度的地方的时间有所不同(地方时)。

1863年,首次使用时区的概念。

时区通过设立一个区域的标准时间部分地解决了这个问题。

世界各个国家位于地球不同位置上,因此不同国家,特别是东西跨度大的国家日出、日落时间必定有所偏差。

这些偏差就是所谓的时差。

为了照顾到各地区的使用方便,又使其他地方的人容易将本地的时间换算到别的地方时间上去。

有关国际会议决定将地球表面按经线从东到西,划成一个个区域,并且规定相邻区域的时间相差1小时。

在同一区域内的东端和西端的人看到太阳升起的时间最多相差不过1小时。

当人们跨过一个区域,就将自己的时钟校正1小时(向西减1小时,向东加1小时

java8中的localdate和localtime用法举例如下:

这两个方法使我们可以方便的实现将旧的日期类转换为新的日期类,具体思路都是通过Instant当中介,然后通过Instant来创建LocalDateTime(这个类可以很容易获取LocalDate和LocalTime),新的日期类转旧的也是如此,将新的先转成LocalDateTime,然后获取Instant,接着转成Date,具体实现细节如下:

// 01. java.util.Date -->java.time.LocalDateTime

public void UDateToLocalDateTime() {

java.util.Date date = new java.util.Date()

Instant instant = date.toInstant()

ZoneId zone = ZoneId.systemDefault()

LocalDateTime localDateTime = LocalDateTime.ofInstant(instant, zone)

}

// 02. java.util.Date -->java.time.LocalDate

public void UDateToLocalDate() {

java.util.Date date = new java.util.Date()

Instant instant = date.toInstant()

ZoneId zone = ZoneId.systemDefault()

LocalDateTime localDateTime = LocalDateTime.ofInstant(instant, zone)

LocalDate localDate = localDateTime.toLocalDate()

}

// 03. java.util.Date -->java.time.LocalTime

public void UDateToLocalTime() {

java.util.Date date = new java.util.Date()

Instant instant = date.toInstant()

ZoneId zone = ZoneId.systemDefault()

LocalDateTime localDateTime = LocalDateTime.ofInstant(instant, zone)

LocalTime localTime = localDateTime.toLocalTime()

}

// 04. java.time.LocalDateTime -->java.util.Date

public void LocalDateTimeToUdate() {

LocalDateTime localDateTime = LocalDateTime.now()

ZoneId zone = ZoneId.systemDefault()

Instant instant = localDateTime.atZone(zone).toInstant()

java.util.Date date = Date.from(instant)

}

// 05. java.time.LocalDate -->java.util.Date

public void LocalDateToUdate() {

LocalDate localDate = LocalDate.now()

ZoneId zone = ZoneId.systemDefault()

Instant instant = localDate.atStartOfDay().atZone(zone).toInstant()

java.util.Date date = Date.from(instant)

}

// 06. java.time.LocalTime -->java.util.Date

public void LocalTimeToUdate() {

LocalTime localTime = LocalTime.now()

LocalDate localDate = LocalDate.now()

LocalDateTime localDateTime = LocalDateTime.of(localDate, localTime)

ZoneId zone = ZoneId.systemDefault()

Instant instant = localDateTime.atZone(zone).toInstant()

java.util.Date date = Date.from(instant)

}

Java 8新增了LocalDate和LocalTime接口,为什么要搞一套全新的处理日期和时间的API?因为旧的java.util.Date实在是太难用了。

java.util.Date月份从0开始,一月是0,十二月是11,变态吧!java.time.LocalDate月份和星期都改成了enum,就不可能再用错了。

java.util.Date和SimpleDateFormatter都不是线程安全的,而LocalDate和LocalTime和最基本的String一样,是不变类型,不但线程安全,而且不能修改。

java.util.Date是一个“万能接口”,它包含日期、时间,还有毫秒数,如果你只想用java.util.Date存储日期,或者只存储时间,那么,只有你知道哪些部分的数据是有用的,哪些部分的数据是不能用的。在新的Java 8中,日期和时间被明确划分为LocalDate和LocalTime,LocalDate无法包含时间,LocalTime无法包含日期。当然,LocalDateTime才能同时包含日期和时间。

新接口更好用的原因是考虑到了日期时间的操作,经常发生往前推或往后推几天的情况。用java.util.Date配合Calendar要写好多代码,而且一般的开发人员还不一定能写对。

LocalDate

看看新的LocalDate怎么用:

// 取当前日期:

LocalDate today = LocalDate.now()// ->2014-12-24

// 根据年月日取日期,12月就是12:

LocalDate crischristmas = LocalDate.of(2014, 12, 25)// ->2014-12-25

// 根据字符串取:

LocalDate endOfFeb = LocalDate.parse("2014-02-28")// 严格按照ISO yyyy-MM-dd验证,02写成2都不行,当然也有一个重载方法允许自己定义格式

LocalDate.parse("2014-02-29")// 无效日期无法通过:DateTimeParseException: Invalid date

日期转换经常遇到,比如:

// 取本月第1天:

LocalDate firstDayOfThisMonth = today.with(TemporalAdjusters.firstDayOfMonth())// 2014-12-01

// 取本月第2天:

LocalDate secondDayOfThisMonth = today.withDayOfMonth(2)// 2014-12-02

// 取本月最后一天,再也不用计算是28,29,30还是31:

LocalDate lastDayOfThisMonth = today.with(TemporalAdjusters.lastDayOfMonth())// 2014-12-31

// 取下一天:

LocalDate firstDayOf2015 = lastDayOfThisMonth.plusDays(1)// 变成了2015-01-01

// 取2015年1月第一个周一,这个计算用Calendar要死掉很多脑细胞:

LocalDate firstMondayOf2015 = LocalDate.parse("2015-01-01").with(TemporalAdjusters.firstInMonth(DayOfWeek.MONDAY))// 2015-01-05

LocalTime

LocalTime只包含时间,以前用java.util.Date怎么才能只表示时间呢?答案是,假装忽略日期。

LocalTime包含毫秒:

LocalTime now = LocalTime.now()// 11:09:09.240

你可能想清除毫秒数:

LocalTime now = LocalTime.now().withNano(0))// 11:09:09

构造时间也很简单:

LocalTime zero = LocalTime.of(0, 0, 0)// 00:00:00

LocalTime mid = LocalTime.parse("12:00:00")// 12:00:00

时间也是按照ISO格式识别,但可以识别以下3种格式:

12:00

12:01:02

12:01:02.345

JDBC

最新JDBC映射将把数据库的日期类型和Java 8的新类型关联起来:

SQL ->Java

--------------------------

date ->LocalDate

time ->LocalTime

timestamp ->LocalDateTime

再也不会出现映射到java.util.Date其中日期或时间某些部分为0的情况了。