如何在Java 8中愉快地处理java 日期时间和时间

未将对象引用设置到对象的实例。如何在Java 8中愉快地处理日期和时间_百度知道
如何在Java 8中愉快地处理日期和时间
提问者采纳
LocalDate月份和星期都改成了enum.firstDayOfMonth())。java.Date实在是太难用了; / 取2015年1月第一个周一;//&#47.parse(&quot:LocalDate lastDayOfThisMonth = today:/ 根据年月日取日期; -&gt,这个计算用Calendar要死掉很多脑细胞;&#47,它包含日期:09; 取本月最后一天.now():LocalDate firstMondayOf2015 = LocalDate:LocalDate endOfFeb = LocalDate,而且一般的开发人员还不一定能写对;/&#47,而且不能修改Java 8新增了LocalDate和LocalTime接口.of(0.Date其中日期或时间某些部分为0的情况了:SQL -&gt,是不变类型:00LocalTime mid = LocalT&#47:09; 11,还有毫秒数:/ &#47?答案是,为什么要搞一套全新的处理日期和时间的API.firstInMonth(DayOfWeek:09; 00。java。java.util,当然也有一个重载方法允许自己定义格式LocalD12:LocalTime now = LocalT / 取本月第1天;/&#47.plusDays(1)。当然;&#47.&#47.with(TemporalA&#47:LocalDate secondDayOfThisMonth = today,29.Date怎么才能只表示时间呢。用 变成了/ / LocalDateTime再也不会出现映射到java.Date是一个“万能接口”;&#47!java,30还是31.time.MONDAY)); &#47?答案是; / 无效日期无法通过,假装忽略日期;); 12, 0; &#47。新接口更好用的原因是考虑到了日期时间的操作; /&#47,以前用 取当前日期; 根据字符串取;):01; &#47。LocalTime包含毫秒。在新的Java 8中;/ LocalTimetimestamp -& Java--------------------------date -&gt,怎么才能愉快地处理日期和时间;&#47:00&quot:00.util:09构造时间也很简单,就不可能再用错了:LocalTime now = LocalTime:01.Date配合Calendar要写好多代码:00时间也是按照ISO格式识别,12月就是12;&#47:02,十二月是11.Date和SimpleDateFormatter都不是线程安全的; / LocalDatetime -&gt,哪些部分的数据是不能用的,只有你知道哪些部分的数据是有用的; &#47,经常发生往前推或往后推几天的情况: Invalid date日期转换经常遇到,日期和时间被明确划分为LocalDate和LocalTime:0012; &#47:DateTimeParseException,而LocalDate和LocalTime和最基本的String一样。LocalDate看看新的LocalDate怎么用;&quot。最后总结一下.with(TemporalAdjusters. /&quot,LocalDateTime才能同时包含日期和时间,不但线程安全、时间.util,但可以识别以下3种格式, 12; LocalTimeLocalTime只包含时间,再也不用计算是28.Date存储日期;&#47:LocalTime zero = LocalTime.parse(&quot, 25);&quot:00; / 取下一天.withDayOfMonth(2); 严格按照ISO yyyy-MM-dd验证:LocalDate firstDayOfThisMonth = today.now();&#47,或者只存储时间:0212:LocalDate crischristmas = LocalDate,02写成2都不行.of(2014.now(),那么?因为旧的java:LocalDate today = LocalDate,变态吧:00.withNano(0));); -&gt.util.parse(&quot.util.Date月份从0开始,LocalDate无法包含时间,一月是0; &#47.util,LocalTime无法包含日期;&#47.with(TemporalA / /&#47:立刻升级到Java 8; &#47.parse(&quot:12;), 0),比如.345JDBC最新JDBC映射将把数据库的日期类型和Java 8的新类型关联起来; 取本月第2天.lastDayOfMonth()):LocalDate firstDayOf2015 = lastDayOfThisM 11.240你可能想清除毫秒数,如果你只想用java
来自团队:
其他类似问题
为您推荐:
java的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁如何在java8中愉快地处理日期和时间java8新增了localdate和localtim_百度知道
如何在java8中愉快地处理日期和时间java8新增了localdate和localtim
java8中的localdate和localtime用法举例如下:这两个方法使我们可以方便的实现将旧的日期类转换为新的日期类,具体思路都是通过Instant当中介,然后通过Instant来创建LocalDateTime(这个类可以很容易获取LocalDate和LocalTime),新的日期类转旧的也是如此,将新的先转成LocalDateTime,然后获取Instant,接着转成Date,具体实现细节如下:
// 01. java.util.Date --& java.time.LocalDateTimepublic 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.LocalDatepublic 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.LocalTimepublic 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.Datepublic 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.Datepublic 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.Datepublic 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);}
其他类似问题
为您推荐:
提问者采纳
/&#47, 25),12月就是12:LocalDate secondDayOfThisMonth =&#47看看新的LocalDate怎么用; &#47:LocalDate firstMondayOf2015 = LocalDate:LocalDate lastDayOfThisMonth =&#47.of(2014;/&#47.firstDayOfMonth()); -& /&#47:/&#47.firstInMonth(DayOfW&#47.parse(& /&quot:LocalDate crischristmas = LocalD); &#47.parse(&quot.with(TemporalA 变成了/ 无效日期无法通过;&#47,比如; 取本月第2天:LocalDate today = LocalD&#47:DateTimeParseE 取下一天,再也不用计算是28;&#47,30还是31,02写成2都不行; / 取当前日期.parse(&quot:LocalDate firstDayOfThisMonth = today.plusDays(1);&quot:LocalDate endOfFeb = LocalD); &#47.with(TemporalA &#47.with(TemporalA 取本月第1天; 根据字符串取;&#47: Invalid date日期转换经常遇到;/& / /); 严格按照ISO yyyy-MM-dd验证;// // &#47.MONDAY)),这个计算用Calendar要死掉很多脑细胞.now(); 取本月最后一天, 12.withDayOfMonth(2):LocalDate firstDayOf2015 = lastDayOfThisM &#47.lastDayOfMonth()); 取2015年1月第一个周一; -& 根据年月日取日期; &#47,29,当然也有一个重载方法允许自己定义格式LocalD &#47:&#47
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁JAVA面试题解惑系列(七)——日期和时间的处理 - 推酷
JAVA面试题解惑系列(七)——日期和时间的处理
日期和时间的处理不仅在面试题中会考到,在实际项目开发中也是我们经常需要处理的问题,似乎没有哪个项目可以避开它们,我们常常在处理用户的出生年月日、注册日期,订单的创建时间等属性时用到,由此可见其重要性。&
java.util.Date类
提到日期和时间,我想大家最先想到应该是java.util.Date类吧。Date类可以精确到毫秒数,这个毫秒数是相对于格林威治标准时间“ 00:00:00.000 GMT”的差值。那么,什么是格林威治标准时间呢?要回答这个问题,我们需要先来了解一下世界时间标准方面的知识。&
世界时间标准主要有UTC,即Coordinated Universal Time(中文名译作世界协调时间、世界统一时间或世界标准时间),以及GMT,即Greenwich Mean Time(中文名译作格林威治标准时间或格林威治平均时间)两种。严格来讲,UTC比GMT更加精确一些,不过它们的差值不会超过0.9秒,如果超过了,将会为UTC增加闰秒以与GMT,也就是地球自转周期保持一致。所以在日常使用中,我们可以把UTC和GMT一样看待。&
日期和时间的表示是与我们所处的时区相关联的,如果我们不指定时区,那么它们将以系统默认的时区来显示。我们先来看看如何创建日期对象。Date类有很多个构造器方法,大部分已经不被赞成使用了(Deprecated),不过还剩下两个可以使用的:&
public Date() {
this(System.currentTimeMillis());
public Date(long date) {
//other code
第一个是无参构造器,使用系统当前时间的毫秒数来创建Date对象,它调用了java.lang.System类的currentTimeMillis()来取得系统的当前时间的毫秒值。这是个本地方法,它的定义如下:&
public static native long currentTimeMillis();
第二个构造器是根据给定的毫秒数来创建一个与之对应的Date对象,这个毫秒数决定了被创建对象的年、月、日、时、分、秒属性的值。&
我们来看看日期和时间在默认时区下的显示效果:&
import java.util.D
public class DateTest {
public static void main(String[] args) {
Date d = new Date();
// 在默认时区下输出日期和时间值
System.out.println(d);
运行结果:&
Tue Jul 22 10:44:47 CST 2008
大家应该注意到了年份前的“CST”标识,它是China Standard Time的缩写,指的是中国标准时间,也就是我们常说的北京时间。它与UTC的时差是UTC+8:00,就是说北京时间比世界标准时间早8个小时,如果世界标准时间是早上1点,北京时间就是早上9点。一般情况下我们不需要关心时区问题。&
在创建完Date对象之后,我们可以通过调用getTime()方法来获得该对象的毫秒数值,调用setTime(long time)方法来设置它的毫秒数值,从而影响年、月、日、时、分、秒这些属性。这两个方法的定义如下:&
public long getTime() {
//other code
public void setTime(long time) {
//other code
既然Date对象可以表示盛相对于“ 00:00:00.000 GMT”的毫秒数,我们自然可以通过这个值来比较两个日期的大小了,不过对于日期来讲,前后的说法应该更为恰当。而Date类已经为我们提供了这样的方法:&
public boolean before(Date when) {
//other code
public boolean after(Date when) {
//other code
public int compareTo(Date anotherDate) {
//other code
before()是判断当前日期是否在参数日期之前,即当前日期毫秒数小于参数日期毫秒数;after()是判断当前日期是否在参数日期之后,即当前日期毫秒数大于参数日期毫秒数。而compareTo()是将当前日期与参数日期比较后,返回一个int型值,它的返回值有三种可能:-1、0和1。如果返回-1则表示当前日期在参数日期之前;如果返回0则表示两个日期是同一时刻;返回1则表示当前日期在参数日期之后。虽然我们可以用compareTo()方法来比较两个Date对象,但是它的设计实际是另有用途的,我们在后面的章节将会讲到。&
下面我们就用一个示例来检验一下以上方法的用法:&
import java.util.D
public class DateTest {
public static void main(String[] args) {
20:00:00对应的毫秒数
long t2008 = 0L;
20:00:00对应的毫秒数
long t1900 = -0L;
// 指定毫秒数创建Date对象
Date d2008 = new Date(t2008);
// 使用系统默认时间创建Date对象
Date d1900 = new Date();
// 通过设置毫秒数改变日期和时间
d1900.setTime(t1900);
System.out.println("调用方法:d1900.before(d2008)");
System.out
.print("比较结果:\" 20:00:00\"在\" 20:00:00\"");
// 使用before()方法比较
if (d1900.before(d2008)) {
System.out.println("之前");
System.out.println("之后");
System.out.println();
System.out.println("调用方法:d2008.after(d1900)");
System.out
.print("比较结果:\" 20:00:00\"在\" 20:00:00\"");
// 使用after()方法比较
if (d2008.after(d1900)) {
System.out.println("之后");
System.out.println("之前");
System.out.println();
System.out.println("调用方法:pareTo(d2008)");
System.out
.print("比较结果:\" 20:00:00\"在\" 20:00:00\"");
// 使用compareTo()方法比较
int i = pareTo(d2008);
if (i == -1) {
System.out.println("之前");
} else if (i == 1) {
System.out.println("之后");
} else if (i == 0) {
System.out.println("是同一时刻");
运行结果:&
调用方法:d1900.before(d2008)
比较结果:& 20:00:00&在& 20:00:00&之前
调用方法:d2008.after(d1900)
比较结果:& 20:00:00&在& 20:00:00&之后
调用方法:pareTo(d2008)
比较结果:& 20:00:00&在& 20:00:00&之前
那么如果我们想直接获取或者改变年、月、日、时、分、秒等等这些属性的值时怎么办呢?Date类当然有完成这些操作的方法,不过遗憾的是它们也都已经不被赞成使用了。我们必须换一个能够提供这些操作的类,这个类就是java.util.Calendar。&
公历历法java.util.GregorianCalendar
Calendar是一个抽象类,我们无法直接实例化它,它有一个具体子类实体类java.util.GregorianCalendar,这个类实现的就是我们日常所用的公历历法,或者叫做阳历。我们可以直接使用new命令创建它的实例,或者使用Calendar类的这个方法来获得它实例:&
public static Calendar getInstance(){
//other code
采用上面这个方法时,我们创建的Calendar对象的日期和时间值是对象被创建时系统日期和时间值。当使用new命令时,我们有两种选择,一种是使用系统当前的日期和时间值初始化GregorianCalendar对象;另一种是通过给定年、月、日、时、分、秒等属性值来对其进行初始化。请看下面的例子:&
import java.text.DateF
import java.text.SimpleDateF
import java.util.C
import java.util.GregorianC
public class DateTest {
* 以一种较为友好的方式格式化日期时间值
* @param c
日期时间对象
* @return 格式化后的日期时间字符串
public static String toFriendlyString(Calendar c) {
if (c != null) {
DateFormat df = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
return df.format(c.getTime());
public static void main(String[] args) {
Calendar c1 = Calendar.getInstance();
System.out.println("创建方式:Calendar.getInstance()");
System.out.println("日期时间:" + DateTest.toFriendlyString(c1));
System.out.println();
Calendar c2 = new GregorianCalendar();
System.out.println("创建方式:new GregorianCalendar()");
System.out.println("日期时间:" + DateTest.toFriendlyString(c2));
System.out.println();
// 参数含义依次为:年、月、日
Calendar c3 = new GregorianCalendar();
System.out.println("创建方式:new GregorianCalendar()");
System.out.println("日期时间:" + DateTest.toFriendlyString(c3));
System.out.println();
// 参数含义依次为:年、月、日、时、分
Calendar c4 = new GregorianCalendar(, 6, 10);
System.out.println("创建方式:new GregorianCalendar(, 6, 10)");
System.out.println("日期时间:" + DateTest.toFriendlyString(c4));
System.out.println();
// 参数含义依次为:年、月、日、时、分、秒
Calendar c5 = new GregorianCalendar(, 18, 10, 5);
System.out.println("创建方式:new GregorianCalendar(, 18, 10, 5)");
System.out.println("日期时间:" + DateTest.toFriendlyString(c5));
运行结果如下:&
创建方式:Calendar.getInstance()
日期时间:日 11:54:48
创建方式:new GregorianCalendar()
日期时间:日 11:54:48
创建方式:new GregorianCalendar()
日期时间:日 00:00:00
创建方式:new GregorianCalendar(, 6, 10)
日期时间:日 06:10:00
创建方式:new GregorianCalendar(, 18, 10, 5)
日期时间:日 18:10:05
为了便于阅读,我们增加一个toFriendlyString(Calendar c)方法,它将日期时间值格式化为一种更加友好易懂的形式,我们将在接下来的内容中讲解它的实现原理。分析运行结果后,我们发现有两个地方需要注意:&
在创建GregorianCalendar对象时,月份值都设定为8,但打印结果都是9月份。这并不是我们的代码有问题,而是因为JAVA表示的月份是从0开始的,也就是说它用来表示月份的数值总是比实际月份值小1。因此我们要表示8月份,就是应该设置8-1=7这个值。
GregorianCalendar的小时数是24小时制的。
为了避免出现因为忘记处理1的差值而设置了错误的月份,也让代码看起来更加直观,推荐大家使用定义在Calendar类的的这些常量来代替直接用数字表示月份:&
一月:Calendar.JANUARY = 0
二月:Calendar.FEBRUARY = 1
三月:Calendar.MARCH = 2
四月:Calendar.APRIL = 3
五月:Calendar.MAY = 4
六月:Calendar.JUNE = 5
七月:Calendar.JULY = 6
八月:Calendar.AUGUST = 7
九月:Calendar.SEPTEMBER = 8
十月:Calendar.OCTOBER = 9
十一月:Calendar.NOVEMBER = 10
十二月:Calendar.DECEMBER = 11
如果我们想要从Calendar对象获得各种属性的值,就需要调用它的get(int field)方法,这个方法接收一个int型的参数,并且根据这个给定参数的值来返回相应的属性的值。该方法的定义如下:&
public int get(int field){
//other code
我们以一个示例来说明get(int field)方法所能接受的一些常用参数的含义及用法:&
import java.text.DateF
import java.text.SimpleDateF
import java.util.C
public class DateTest {
* 以一种较为友好的方式格式化日期时间值
* @param c
日期时间对象
* @return 格式化后的日期时间字符串
public static String toFriendlyString(Calendar c) {
if (c != null) {
DateFormat df = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss.SSS");
return df.format(c.getTime());
public static void main(String[] args) {
Calendar c = Calendar.getInstance();
System.out.println("当前时刻:" + DateTest.toFriendlyString(c));
System.out.println();
System.out.println("属性名称:Calendar.AM_PM");
System.out.println("代表含义:上下午标识,上午返回Calendar.AM=0,下午返回Calendar.PM=1");
System.out.println("测试结果:" + c.get(Calendar.AM_PM));
System.out.println();
System.out.println("属性名称:Calendar.DATE");
System.out.println("代表含义:一个月中的第几天,同Calendar.DAY_OF_MONTH");
System.out.println("测试结果:" + c.get(Calendar.DATE));
System.out.println();
System.out.println("属性名称:Calendar.DAY_OF_MONTH");
System.out.println("代表含义:一个月中的第几天,同Calendar.DATE");
System.out.println("测试结果:" + c.get(Calendar.DAY_OF_MONTH));
System.out.println();
System.out.println("属性名称:Calendar.DAY_OF_WEEK");
System.out.println("代表含义:一周中的第几天,对应星期几,第一天为星期日,于此类推。");
System.out.println("星期日:Calendar.SUNDAY=1");
System.out.println("星期一:Calendar.MONDAY=2");
System.out.println("星期二:Calendar.TUESDAY=3");
System.out.println("星期三:Calendar.WEDNESDAY=4");
System.out.println("星期四:Calendar.THURSDAY=5");
System.out.println("星期五:Calendar.FRIDAY=6");
System.out.println("星期六:Calendar.SATURDAY=7");
System.out.println("测试结果:" + c.get(Calendar.DAY_OF_WEEK));
System.out.println();
System.out.println("属性名称:Calendar.DAY_OF_WEEK_IN_MONTH");
System.out.println("代表含义:这一天所对应的星期几在该月中是第几次出现");
System.out.println("测试结果:" + c.get(Calendar.DAY_OF_WEEK_IN_MONTH));
System.out.println();
System.out.println("属性名称:Calendar.DAY_OF_YEAR");
System.out.println("代表含义:一年中的第几天");
System.out.println("测试结果:" + c.get(Calendar.DAY_OF_YEAR));
System.out.println();
System.out.println("属性名称:Calendar.HOUR");
System.out.println("代表含义:12小时制下的小时数,中午和午夜表示为0");
System.out.println("测试结果:" + c.get(Calendar.HOUR));
System.out.println();
System.out.println("属性名称:Calendar.HOUR_OF_DAY");
System.out.println("代表含义:24小时制下的小时数,午夜表示为0");
System.out.println("测试结果:" + c.get(Calendar.HOUR_OF_DAY));
System.out.println();
System.out.println("属性名称:Calendar.MILLISECOND");
System.out.println("代表含义:毫秒数");
System.out.println("测试结果:" + c.get(Calendar.MILLISECOND));
System.out.println();
System.out.println("属性名称:Calendar.MINUTE");
System.out.println("代表含义:分钟");
System.out.println("测试结果:" + c.get(Calendar.MINUTE));
System.out.println();
System.out.println("属性名称:Calendar.MONTH");
System.out.println("代表含义:月份,从0到11表示12个月份,比实际月份值小1");
System.out.println("测试结果:" + c.get(Calendar.MONTH));
System.out.println();
System.out.println("属性名称:Calendar.SECOND");
System.out.println("代表含义:秒");
System.out.println("测试结果:" + c.get(Calendar.SECOND));
System.out.println();
System.out.println("属性名称:Calendar.WEEK_OF_MONTH");
System.out.println("代表含义:一个月中的第几个星期");
System.out.println("测试结果:" + c.get(Calendar.WEEK_OF_MONTH));
System.out.println();
System.out.println("属性名称:Calendar.WEEK_OF_YEAR");
System.out.println("代表含义:一年中的第几个星期");
System.out.println("测试结果:" + c.get(Calendar.WEEK_OF_YEAR));
System.out.println();
System.out.println("属性名称:Calendar.YEAR");
System.out.println("代表含义:年份");
System.out.println("测试结果:" + c.get(Calendar.YEAR));
运行结果如下:&
当前时刻:日 13:16:07.421
属性名称:Calendar.AM_PM
代表含义:上下午标识,上午返回Calendar.AM=0,下午返回Calendar.PM=1
测试结果:1
属性名称:Calendar.DATE
代表含义:一个月中的第几天,同Calendar.DAY_OF_MONTH
测试结果:22
属性名称:Calendar.DAY_OF_MONTH
代表含义:一个月中的第几天,同Calendar.DATE
测试结果:22
属性名称:Calendar.DAY_OF_WEEK
代表含义:一周中的第几天,对应星期几,第一天为星期日,于此类推。
星期日:Calendar.SUNDAY=1
星期一:Calendar.MONDAY=2
星期二:Calendar.TUESDAY=3
星期三:Calendar.WEDNESDAY=4
星期四:Calendar.THURSDAY=5
星期五:Calendar.FRIDAY=6
星期六:Calendar.SATURDAY=7
测试结果:3
属性名称:Calendar.DAY_OF_WEEK_IN_MONTH
代表含义:这一天所对应的星期几在该月中是第几次出现
测试结果:4
属性名称:Calendar.DAY_OF_YEAR
代表含义:一年中的第几天
测试结果:204
属性名称:Calendar.HOUR
代表含义:12小时制下的小时数,中午和午夜表示为0
测试结果:1
属性名称:Calendar.HOUR_OF_DAY
代表含义:24小时制下的小时数,午夜表示为0
测试结果:13
属性名称:Calendar.MILLISECOND
代表含义:毫秒数
测试结果:421
属性名称:Calendar.MINUTE
代表含义:分钟
测试结果:16
属性名称:Calendar.MONTH
代表含义:月份,从0到11表示12个月份,比实际月份值小1
测试结果:6
属性名称:Calendar.SECOND
代表含义:秒
测试结果:7
属性名称:Calendar.WEEK_OF_MONTH
代表含义:一个月中的第几个星期
测试结果:4
属性名称:Calendar.WEEK_OF_YEAR
代表含义:一年中的第几个星期
测试结果:30
属性名称:Calendar.YEAR
代表含义:年份
测试结果:2008
其中Calendar.DAY_OF_WEEK_IN_MONTH代表的含义比较难理解一些,它表示“这一天所对应的星期几在该月中是第几次出现”。比如日是星期五,在它之前的8月1日也是星期五,因此它是8月份的第二个星期五。所以这时调用get(Calendar.DAY_OF_WEEK_IN_MONTH)就会返回2。这里存在一个简单易记的规律:对于每月的1-7号,它们一定占全了星期一到星期日,所以不管是它们中的哪一天,也不管这一天是星期几,它总是第一个,因此返回1;8-14号也同样占全了星期一到星期日,但由于1-7号的关系,对于它们总是返回2;以此类推,15-21号返回3,22-28号返回4,29-31号返回5。&
Calendar对象和Date对象可以通过Calendar类的如下两个方法进行相互转换:&
public final Date getTime() {
//other code
public final void setTime(Date date) {
//other code
日期格式化与解析
我们回头再来看看在上面的例子中定义的toFriendlyString(Calendar c)方法,它将一个Calendar对象的日期时间值以一种很友好的方式来展现,使人们很容易看懂,也符合我们中国人的习惯。这完全得益于抽象类DateFormat以及它的子类实体类SimpleDateFormat的帮助。这两个类都位于java.text包中,是专门用于日期格式化和解析的类。而这两项工作的核心就是我们为此设定的Pattern,我们可以称之为“日期格式表达式”。&
理论上讲日期格式表达式包含全部26个英文字母的大小写,不过它们中的一些字母只是被预留了,并没有确切的含义。目前有效的字母及它们所代表的含义如下:&
G:年代标识,表示是公元前还是公元后
h:小时,从1到12,分上下午
H:小时,从0到23
E:一周中的第几天,对应星期几,第一天为星期日,于此类推
D:一年中的第几天
F:这一天所对应的星期几在该月中是第几次出现
w:一年中的第几个星期
W:一个月中的第几个星期
a:上午/下午标识
k:小时,从1到24
K:小时,从0到11,区分上下午
在日期格式表达式中出现的所有字母,在进行日期格式化操作后,都将被其所代表的含义对应的属性值所替换,并且对某些字母来说,重复次数的不同,格式化后的结果也会有所不同。请看下面的例子:&
import java.text.SimpleDateF
import java.util.D
public class DateTest {
public static void main(String[] args) {
// 使用系统当前日期时间值创建一个Date对象
Date now = new Date();
// 创建一个日期格式表达式
String pattern = "年代:G;年份:y;月份:M;日:d;时(1~12):h;时(0~23):H;分:m;秒:s;毫秒:S;星期:E;上/下午:a;时区:z";
// 使用日期格式表达式创建一个SimpleDateFormat对象
SimpleDateFormat df = new SimpleDateFormat(pattern);
// 调用SimpleDateFormat类的format(Date date)方法对Date对象进行格式化,并返回格式化后的字符串。
// 该方法继承自java.text.DateFormat类
System.out.println("1位:" + df.format(now));
// 创建一个新的日期格式表达式
pattern = "年代:GG;年份:月份:MM;日:时(1~12):时(0~23):HH;分:秒:毫秒:SS;星期:EE;上/下午:时区:zz";
// 调用SimpleDateFormat的applyPattern(String pattern)方法用新创建的日期格式表达式替换其原有的
df.applyPattern(pattern);
System.out.println("2位:" + df.format(now));
pattern = "年代:GGG;年份:月份:MMM;日:时(1~12):时(0~23):HHH;分:秒:毫秒:SSS;星期:EEE;上/下午:时区:zzz";
df.applyPattern(pattern);
System.out.println("3位:" + df.format(now));
pattern = "年代:GGGG;年份:月份:MMMM;日:时(1~12):时(0~23):HHHH;分:秒:毫秒:SSSS;星期:EEEE;上/下午:时区:zzzz";
df.applyPattern(pattern);
System.out.println("4位:" + df.format(now));
pattern = "年代:GGGGG;年份:月份:MMMMM;日:时(1~12):时(0~23):HHHHH;分:秒:毫秒:SSSSS;星期:EEEEE;上/下午:时区:zzzzz";
df.applyPattern(pattern);
System.out.println("5位:" + df.format(now));
pattern = "年代:GGGGGG;年份:月份:MMMMMM;日:时(1~12):时(0~23):HHHHHH;分:秒:毫秒:SSSSSS;星期:EEEEEE;上/下午:时区:zzzzzz";
df.applyPattern(pattern);
System.out.println("6位:" + df.format(now));
输出结果如下:&
1位:年代:公元;年份:08;月份:7;日:22;时(1~12):3;时(0~23):15;分:17;秒:49;毫秒:187;星期:星期二;上/下午:下午;时区:CST
2位:年代:公元;年份:08;月份:07;日:22;时(1~12):03;时(0~23):15;分:17;秒:49;毫秒:187;星期:星期二;上/下午:下午;时区:CST
3位:年代:公元;年份:08;月份:七月;日:022;时(1~12):003;时(0~23):015;分:017;秒:049;毫秒:187;星期:星期二;上/下午:下午;时区:CST
4位:年代:公元;年份:2008;月份:七月;日:0022;时(1~12):0003;时(0~23):0015;分:0017;秒:0049;毫秒:0187;星期:星期二;上/下午:下午;时区:中国标准时间
5位:年代:公元;年份:02008;月份:七月;日:00022;时(1~12):00003;时(0~23):00015;分:00017;秒:00049;毫秒:00187;星期:星期二;上/下午:下午;时区:中国标准时间
6位:年代:公元;年份:002008;月份:七月;日:000022;时(1~12):000003;时(0~23):000015;分:000017;秒:000049;毫秒:000187;星期:星期二;上/下午:下午;时区:中国标准时间
如果我们想输出原始的字母,而不是它们所代表含义的替换值,就需要用单引号将它们包含在内,对于预留字母也是如此,虽然它们没有确切的含义。一对单引号可以一次包含多个字母,而两个连续的单引号将输出一个单引号结果,双引号则需要转义后输出。对于26个字母之外的字符,可以放在一对单引号中,也可以直接书写。请看下面的例子:
import java.text.SimpleDateF
import java.util.D
public class Test {
public static void main(String[] args) {
Date now = new Date();
SimpleDateFormat df = new SimpleDateFormat(
"'YEAR': yyyy 'MONTH:' ''MM'' 'DAY:' \"dd\" ");
System.out.println(df.format(now));
运行结果:&
YEAR: 2008 MONTH: '07' DAY: &22&
上面的一些例子中,我们将日期对象转换成一定格式的字符串输出,以得到符合我们习惯的较为友好的表现形式。我们还可以反过来,使用DateFormat类的parse(String source)方法将具有一定格式的字符串转换为一个Date对象,前提是我们利用前面讲到日期格式表达式语法为其找到一个合适的Pattern。例如:&
import java.text.ParseE
import java.text.SimpleDateF
import java.util.D
public class DateTest {
public static void main(String[] args) throws ParseException {
String s = "";
System.out.println("原始字符串:" + s);
String pattern = "yyyy-MM-dd";
System.out.println("对应表达式:" + pattern);
SimpleDateFormat df = new SimpleDateFormat(pattern);
Date date = df.parse(s);
System.out.println("转换后的值:" + date);
System.out.println();
s = "05年2月12日 18:04:33";
System.out.println("原始字符串:" + s);
pattern = "yy年M月d日 HH:mm:ss";
System.out.println("对应表达式:" + pattern);
df.applyPattern(pattern);
date = df.parse(s);
System.out.println("转换后的值:" + date);
System.out.println();
s = "16/5/:2.050";
System.out.println("原始字符串:" + s);
pattern = "d/M/yyyy HH:m:s.SSS";
System.out.println("对应表达式:" + pattern);
df.applyPattern(pattern);
date = df.parse(s);
System.out.println("转换后的值:" + date);
运行结果:&
原始字符串:
对应表达式:yyyy-MM-dd
转换后的值:Fri Aug 08 00:00:00 CST 2008
原始字符串:05年2月12日 18:04:33
对应表达式:yy年M月d日 HH:mm:ss
转换后的值:Sat Feb 12 18:04:33 CST 2005
原始字符串:16/5/:2.050
对应表达式:d/M/yyyy HH:m:s.SSS
转换后的值:Sun May 16 20:07:02 CST 2004
已发表评论数()
请填写推刊名
描述不能大于100个字符!
权限设置: 公开
仅自己可见
正文不准确
标题不准确
排版有问题
主题不准确
没有分页内容
图片无法显示
视频无法显示
与原文不一致

我要回帖

更多关于 java获取当前日期时间 的文章

 

随机推荐