- 浏览: 157371 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
lovelimx:
最后一个java文件第37行 orignal = new S ...
JAVA笔试面试必考题系列(六)——字符串(String)杂谈 -
ponlya:
下午又去下了个eclipse3.4,再按这方法,ok了。谢谢楼 ...
eclipse 3.4 下配置 Hibernate tool工具 -
ponlya:
如楼主所说的第1,2步,我在第3步中怎么得不到那个文件夹?换用 ...
eclipse 3.4 下配置 Hibernate tool工具 -
chinaboby2008:
...
JBoss目录结构说明 -
chinaboby2008:
这是java中的j2se部分。是java的基础呢。
有关Java容器的基础知识
JAVA面试题解惑系列(七)——日期和时间的处理
关键字: java 面试题 日期 时间 转换
作者:臧圩人(zangweiren)
网址:http://zangweiren.iteye.com
>>>转载请注明出处!<<<
日期和时间的处理不仅在面试题中会考到,在实际项目开发中也是我们经常需要处理的问题,似乎没有哪个项目可以避开它们,我们常常在处理用户的出生年月日、注册日期,订单的创建时间等属性时用到,由此可见其重要性。
java.util.Date类
提到日期和时间,我想大家最先想到应该是java.util.Date类吧。Date类可以精确到毫秒数,这个毫秒数是相对于格林威治标准时间“1970-01-01 00:00:00.000 GMT”的差值。那么,什么是格林威治标准时间呢?要回答这个问题,我们需要先来了解一下世界时间标准方面的知识。
世界时间标准主要有UTC,即Coordinated Universal Time(中文名译作世界协调时间、世界统一时间或世界标准时间),以及GMT,即Greenwich Mean Time(中文名译作格林威治标准时间或格林威治平均时间)两种。严格来讲,UTC比GMT更加精确一些,不过它们的差值不会超过0.9秒,如果超过了,将会为UTC增加闰秒以与GMT,也就是地球自转周期保持一致。所以在日常使用中,我们可以把UTC和GMT一样看待。
日期和时间的表示是与我们所处的时区相关联的,如果我们不指定时区,那么它们将以系统默认的时区来显示。我们先来看看如何创建日期对象。Date类有很多个构造器方法,大部分已经不被赞成使用了(Deprecated),不过还剩下两个可以使用的:
第一个是无参构造器,使用系统当前时间的毫秒数来创建Date对象,它调用了java.lang.System类的currentTimeMillis()来取得系统的当前时间的毫秒值。这是个本地方法,它的定义如下:
第二个构造器是根据给定的毫秒数来创建一个与之对应的Date对象,这个毫秒数决定了被创建对象的年、月、日、时、分、秒属性的值。
我们来看看日期和时间在默认时区下的显示效果:
运行结果:
大家应该注意到了年份前的“CST”标识,它是China Standard Time的缩写,指的是中国标准时间,也就是我们常说的北京时间。它与UTC的时差是UTC+8:00,就是说北京时间比世界标准时间早8个小时,如果世界标准时间是早上1点,北京时间就是早上9点。一般情况下我们不需要关心时区问题。
在创建完Date对象之后,我们可以通过调用getTime()方法来获得该对象的毫秒数值,调用setTime(long time)方法来设置它的毫秒数值,从而影响年、月、日、时、分、秒这些属性。这两个方法的定义如下:
既然Date对象可以表示盛相对于“1970-01-01 00:00:00.000 GMT”的毫秒数,我们自然可以通过这个值来比较两个日期的大小了,不过对于日期来讲,前后的说法应该更为恰当。而Date类已经为我们提供了这样的方法:
before()是判断当前日期是否在参数日期之前,即当前日期毫秒数小于参数日期毫秒数;after()是判断当前日期是否在参数日期之后,即当前日期毫秒数大于参数日期毫秒数。而compareTo()是将当前日期与参数日期比较后,返回一个int型值,它的返回值有三种可能:-1、0和1。如果返回-1则表示当前日期在参数日期之前;如果返回0则表示两个日期是同一时刻;返回1则表示当前日期在参数日期之后。虽然我们可以用compareTo()方法来比较两个Date对象,但是它的设计实际是另有用途的,我们在后面的章节将会讲到。
下面我们就用一个示例来检验一下以上方法的用法:
运行结果:
那么如果我们想直接获取或者改变年、月、日、时、分、秒等等这些属性的值时怎么办呢?Date类当然有完成这些操作的方法,不过遗憾的是它们也都已经不被赞成使用了。我们必须换一个能够提供这些操作的类,这个类就是java.util.Calendar。
公历历法java.util.GregorianCalendar
Calendar是一个抽象类,我们无法直接实例化它,它有一个具体子类实体类java.util.GregorianCalendar,这个类实现的就是我们日常所用的公历历法,或者叫做阳历。我们可以直接使用new命令创建它的实例,或者使用Calendar类的这个方法来获得它实例:
采用上面这个方法时,我们创建的Calendar对象的日期和时间值是对象被创建时系统日期和时间值。当使用new命令时,我们有两种选择,一种是使用系统当前的日期和时间值初始化GregorianCalendar对象;另一种是通过给定年、月、日、时、分、秒等属性值来对其进行初始化。请看下面的例子:
运行结果如下:
为了便于阅读,我们增加一个toFriendlyString(Calendar c)方法,它将日期时间值格式化为一种更加友好易懂的形式,我们将在接下来的内容中讲解它的实现原理。分析运行结果后,我们发现有两个地方需要注意:
为了避免出现因为忘记处理1的差值而设置了错误的月份,也让代码看起来更加直观,推荐大家使用定义在Calendar类的的这些常量来代替直接用数字表示月份:
如果我们想要从Calendar对象获得各种属性的值,就需要调用它的get(int field)方法,这个方法接收一个int型的参数,并且根据这个给定参数的值来返回相应的属性的值。该方法的定义如下:
我们以一个示例来说明get(int field)方法所能接受的一些常用参数的含义及用法:
运行结果如下:
其中Calendar.DAY_OF_WEEK_IN_MONTH代表的含义比较难理解一些,它表示“这一天所对应的星期几在该月中是第几次出现”。比如2008年8月8日是星期五,在它之前的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类的如下两个方法进行相互转换:
日期格式化与解析
我们回头再来看看在上面的例子中定义的toFriendlyString(Calendar c)方法,它将一个Calendar对象的日期时间值以一种很友好的方式来展现,使人们很容易看懂,也符合我们中国人的习惯。这完全得益于抽象类DateFormat以及它的子类实体类SimpleDateFormat的帮助。这两个类都位于java.text包中,是专门用于日期格式化和解析的类。而这两项工作的核心就是我们为此设定的Pattern,我们可以称之为“日期格式表达式”。
理论上讲日期格式表达式包含全部26个英文字母的大小写,不过它们中的一些字母只是被预留了,并没有确切的含义。目前有效的字母及它们所代表的含义如下:
在日期格式表达式中出现的所有字母,在进行日期格式化操作后,都将被其所代表的含义对应的属性值所替换,并且对某些字母来说,重复次数的不同,格式化后的结果也会有所不同。请看下面的例子:
网址:http://zangweiren.iteye.com
>>>转载请注明出处!<<<
日期和时间的处理不仅在面试题中会考到,在实际项目开发中也是我们经常需要处理的问题,似乎没有哪个项目可以避开它们,我们常常在处理用户的出生年月日、注册日期,订单的创建时间等属性时用到,由此可见其重要性。
java.util.Date类
提到日期和时间,我想大家最先想到应该是java.util.Date类吧。Date类可以精确到毫秒数,这个毫秒数是相对于格林威治标准时间“1970-01-01 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.Date;
- public class DateTest {
- public static void main(String[] args) {
- Date d = new Date();
- // 在默认时区下输出日期和时间值
- System.out.println(d);
- }
- }
import java.util.Date; 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对象可以表示盛相对于“1970-01-01 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
- }
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.Date;
- public class DateTest {
- public static void main(String[] args) {
- // 2008-08-08 20:00:00对应的毫秒数
- long t2008 = 1218196800000L;
- // 1900-01-01 20:00:00对应的毫秒数
- long t1900 = -2208945952000L;
- // 指定毫秒数创建Date对象
- Date d2008 = new Date(t2008);
- // 使用系统默认时间创建Date对象
- Date d1900 = new Date();
- // 通过设置毫秒数改变日期和时间
- d1900.setTime(t1900);
- System.out.println("调用方法:d1900.before(d2008)");
- System.out
- .print("比较结果:\"1900-01-01 20:00:00\"在\"2008-08-08 20:00:00\"");
- // 使用before()方法比较
- if (d1900.before(d2008)) {
- System.out.println("之前");
- } else {
- System.out.println("之后");
- }
- System.out.println();
- System.out.println("调用方法:d2008.after(d1900)");
- System.out
- .print("比较结果:\"2008-08-08 20:00:00\"在\"1900-01-01 20:00:00\"");
- // 使用after()方法比较
- if (d2008.after(d1900)) {
- System.out.println("之后");
- } else {
- System.out.println("之前");
- }
- System.out.println();
- System.out.println("调用方法:d1900.compareTo(d2008)");
- System.out
- .print("比较结果:\"1900-01-01 20:00:00\"在\"2008-08-08 20:00:00\"");
- // 使用compareTo()方法比较
- int i = d1900.compareTo(d2008);
- if (i == -1) {
- System.out.println("之前");
- } else if (i == 1) {
- System.out.println("之后");
- } else if (i == 0) {
- System.out.println("是同一时刻");
- }
- }
- }
import java.util.Date; public class DateTest { public static void main(String[] args) { // 2008-08-08 20:00:00对应的毫秒数 long t2008 = 1218196800000L; // 1900-01-01 20:00:00对应的毫秒数 long t1900 = -2208945952000L; // 指定毫秒数创建Date对象 Date d2008 = new Date(t2008); // 使用系统默认时间创建Date对象 Date d1900 = new Date(); // 通过设置毫秒数改变日期和时间 d1900.setTime(t1900); System.out.println("调用方法:d1900.before(d2008)"); System.out .print("比较结果:\"1900-01-01 20:00:00\"在\"2008-08-08 20:00:00\""); // 使用before()方法比较 if (d1900.before(d2008)) { System.out.println("之前"); } else { System.out.println("之后"); } System.out.println(); System.out.println("调用方法:d2008.after(d1900)"); System.out .print("比较结果:\"2008-08-08 20:00:00\"在\"1900-01-01 20:00:00\""); // 使用after()方法比较 if (d2008.after(d1900)) { System.out.println("之后"); } else { System.out.println("之前"); } System.out.println(); System.out.println("调用方法:d1900.compareTo(d2008)"); System.out .print("比较结果:\"1900-01-01 20:00:00\"在\"2008-08-08 20:00:00\""); // 使用compareTo()方法比较 int i = d1900.compareTo(d2008); if (i == -1) { System.out.println("之前"); } else if (i == 1) { System.out.println("之后"); } else if (i == 0) { System.out.println("是同一时刻"); } } }
运行结果:
- 调用方法:d1900.before(d2008)
- 比较结果:"1900-01-01 20:00:00"在"2008-08-08 20:00:00"之前
- 调用方法:d2008.after(d1900)
- 比较结果:"2008-08-08 20:00:00"在"1900-01-01 20:00:00"之后
- 调用方法:d1900.compareTo(d2008)
- 比较结果:"1900-01-01 20:00:00"在"2008-08-08 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.DateFormat;
- import java.text.SimpleDateFormat;
- import java.util.Calendar;
- import java.util.GregorianCalendar;
- 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());
- }
- return null;
- }
- 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(2008, 8, 8);
- System.out.println("创建方式:new GregorianCalendar(2008, 8, 8)");
- System.out.println("日期时间:" + DateTest.toFriendlyString(c3));
- System.out.println();
- // 参数含义依次为:年、月、日、时、分
- Calendar c4 = new GregorianCalendar(2008, 8, 8, 6, 10);
- System.out.println("创建方式:new GregorianCalendar(2008, 8, 8, 6, 10)");
- System.out.println("日期时间:" + DateTest.toFriendlyString(c4));
- System.out.println();
- // 参数含义依次为:年、月、日、时、分、秒
- Calendar c5 = new GregorianCalendar(2008, 8, 8, 18, 10, 5);
- System.out.println("创建方式:new GregorianCalendar(2008, 8, 8, 18, 10, 5)");
- System.out.println("日期时间:" + DateTest.toFriendlyString(c5));
- }
- }
import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.GregorianCalendar; 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()); } return null; } 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(2008, 8, 8); System.out.println("创建方式:new GregorianCalendar(2008, 8, 8)"); System.out.println("日期时间:" + DateTest.toFriendlyString(c3)); System.out.println(); // 参数含义依次为:年、月、日、时、分 Calendar c4 = new GregorianCalendar(2008, 8, 8, 6, 10); System.out.println("创建方式:new GregorianCalendar(2008, 8, 8, 6, 10)"); System.out.println("日期时间:" + DateTest.toFriendlyString(c4)); System.out.println(); // 参数含义依次为:年、月、日、时、分、秒 Calendar c5 = new GregorianCalendar(2008, 8, 8, 18, 10, 5); System.out.println("创建方式:new GregorianCalendar(2008, 8, 8, 18, 10, 5)"); System.out.println("日期时间:" + DateTest.toFriendlyString(c5)); } }
运行结果如下:
- 创建方式:Calendar.getInstance()
- 日期时间:2008年07月22日 11:54:48
- 创建方式:new GregorianCalendar()
- 日期时间:2008年07月22日 11:54:48
- 创建方式:new GregorianCalendar(2008, 8,
- 日期时间:2008年09月08日 00:00:00
- 创建方式:new GregorianCalendar(2008, 8, 8, 6, 10)
- 日期时间:2008年09月08日 06:10:00
- 创建方式:new GregorianCalendar(2008, 8, 8, 18, 10, 5)
- 日期时间:2008年09月08日 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.DateFormat;
- import java.text.SimpleDateFormat;
- import java.util.Calendar;
- 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());
- }
- return null;
- }
- 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));
- }
- }
import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Calendar; 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()); } return null; } 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)); } }
运行结果如下:
- 当前时刻:2008年07月22日 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代表的含义比较难理解一些,它表示“这一天所对应的星期几在该月中是第几次出现”。比如2008年8月8日是星期五,在它之前的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
- }
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:年代标识,表示是公元前还是公元后
- y:年份
- M:月份
- d:日
- h:小时,从1到12,分上下午
- H:小时,从0到23
- m:分钟
- s:秒
- S:毫秒
- E:一周中的第几天,对应星期几,第一天为星期日,于此类推
- z:时区
- D:一年中的第几天
- F:这一天所对应的星期几在该月中是第几次出现
- w:一年中的第几个星期
- W:一个月中的第几个星期
- a:上午/下午标识
- k:小时,从1到24
- K:小时,从0到11,区分上下午
在日期格式表达式中出现的所有字母,在进行日期格式化操作后,都将被其所代表的含义对应的属性值所替换,并且对某些字母来说,重复次数的不同,格式化后的结果也会有所不同。请看下面的例子:
- import java.text.SimpleDateFormat;
- import java.util.Date;
- public class DateTest {
- public static void main(String[] args) {
- // 使用系统当前日期时间值创建一个Date对象
- Date now = new Date();
-
color: #00820
发表评论
-
JAVA笔试面试必考题系列(十一)——这些运算符你是否还记得?
2009-07-01 11:00 1413JAVA面试题解惑系列(十一)——这些运算符你是否还记得? ... -
JAVA笔试面试必考题系列(十)——话说多线程
2009-07-01 10:59 4174JAVA面试题解惑系列(十)——话说多线程 关键字: jav ... -
JAVA笔试面试必考题系列(九)——继承、多态、重载和重写
2009-07-01 10:58 2394JAVA面试题解惑系列(九 ... -
JAVA笔试面试必考题系列(八)——聊聊基本类型(内置类型)
2009-07-01 10:57 1448JAVA面试题解惑系列(八)——聊聊基本类型(内置类型) 关 ... -
JAVA笔试面试必考题系列(六)——字符串(String)杂谈
2009-07-01 10:55 2283JAVA面试题解惑系列(六)——字符串(String)杂谈 ... -
JAVA笔试面试必考题系列(五)——传了值还是传了引用?
2009-07-01 10:53 1275JAVA面试题解惑系列(五)——传了值还是传了引用? 关键字 ... -
JAVA笔试面试必考题系列(四)——final、finally和finalize的区别
2009-07-01 10:52 1248JAVA面试题解惑系列(四 ... -
JAVA笔试面试必考题系列(三)——变量(属性)的覆盖
2009-07-01 10:50 1209JAVA面试题解惑系列(三)——变量(属性)的覆盖 关键字: ... -
java笔试面试必考题(二)到底创建了几个String对象
2009-06-24 16:10 1558(二)到底创建了几个String对象?关键字: java 面试 ... -
java笔试必考题(一)类的初始化顺序
2009-06-24 15:34 1399(一)类的初始化顺序关键字: java 面试题 初始化 发布时 ... -
各种排序算法java实现
2009-05-11 16:40 905插入排序: package org.rut.util.a ... -
笔试(一)
2009-05-08 10:16 1151一、判断题(30分) 1. ... -
程序员面试之葵花宝典
2009-05-08 10:15 1218程序员面试之葵花宝典 面向对象的特征有哪些 ...
相关推荐
java面试笔试题库java笔试题大集合及答案互联网公司面试资料Java面试问题集大全合集(200个): JavaEE学习笔记.pdf java_Java_学习笔记.pdf Java_Performance.pdf java代码效率优化.docx Java内存模型的历史变迁....
【标题】"北京衮雪技术有限公司Java笔试面试题"揭示了这是一份针对应聘该公司Java开发岗位的考生准备的考题集。这份资料可能包含了Java编程的基础知识、进阶概念以及实际问题解决能力的考察。 【描述】"北京衮雪...
│ JAVA笔试题(上海释锐).pdf │ MIME简介.txt │ SCJP试题详解.pdf │ SQL面试题_心灵深处.htm │ Struts+Hibernate+Spring轻量级J2EE企业应用实战.pdf │ Struts中文手册.pdf │ Struts配置文件详解.txt │ 上海...
通过上述分析,我们不仅深入了解了Java上机面试的常见题目——字符串截取的解决方案,还掌握了处理多字节字符的关键技术。这种类型的题目不仅考验应聘者的基础知识,更对其逻辑思维和问题解决能力提出了挑战。对于...
│ JAVA笔试题(上海释锐).pdf │ MIME简介.txt │ SCJP试题详解.pdf │ SQL面试题_心灵深处.htm │ Struts+Hibernate+Spring轻量级J2EE企业应用实战.pdf │ Struts中文手册.pdf │ Struts配置文件详解.txt │ 上海...
JAVA面试题解惑系列.pdf Java面试题(基础).pdf JVM 实用参数系列 - v1.0.pdf JVM与性能优化知识点整理.pdf JVM面试专题.docx JVM面试专题及答案.pdf Linux系统Redis笔记.docx MongoDB学习笔记.docx mybatis原理....
这本宝典不仅提供了一系列实战案例,还深入探讨了Java程序员面试中常见的基础性问题,例如`final`关键字、`super`关键字的用法、构造函数的概念及其应用场景等。通过这些具体的知识点学习,求职者能够更好地准备面试...
│ JAVA笔试题(上海释锐).pdf │ MIME简介.txt │ SCJP试题详解.pdf │ SQL面试题_心灵深处.htm │ Struts+Hibernate+Spring轻量级J2EE企业应用实战.pdf │ Struts中文手册.pdf │ Struts配置文件详解.txt │ 上海...
│ JAVA笔试题(上海释锐).pdf │ MIME简介.txt │ SCJP试题详解.pdf │ SQL面试题_心灵深处.htm │ Struts+Hibernate+Spring轻量级J2EE企业应用实战.pdf │ Struts中文手册.pdf │ Struts配置文件详解.txt │ 上海...
│ JAVA笔试题(上海释锐).pdf │ MIME简介.txt │ SCJP试题详解.pdf │ SQL面试题_心灵深处.htm │ Struts+Hibernate+Spring轻量级J2EE企业应用实战.pdf │ Struts中文手册.pdf │ Struts配置文件详解.txt │ 上海...
【标题】:“北京第一纪信息技术有限公司Java笔试题”通常指的是该公司在招聘Java开发人员时使用的考试题目集,旨在测试应聘者的Java编程技能、基础知识以及问题解决能力。这类试题可能涵盖面向对象编程、数据结构与...
3. **编程能力**:软件测试工程师通常需要有一定的编程能力,因此笔试可能包含编程题,涉及C++、Java、Python等语言,可能涉及到算法设计和实现、数据结构理解以及代码调试。 4. **行业知识**:虹软在图像处理领域...
### sun认证SCJP——大企业笔试题来源 #### 背景介绍 在IT行业中,Sun Microsystems曾经是一家非常重要的公司,特别是在Java编程领域。Sun Microsystems提供了多种认证项目,包括Sun Certified Java Programmer ...
5. **异常处理**:Java通过异常处理机制来捕获和处理程序运行时可能出现的错误。异常是通过try-catch-finally块来处理的,可以有效避免程序因错误而中断。 6. **集合框架**:Java集合框架提供了一组接口和类,用于...
本篇文章将详细解析一道常见的Java笔试题——特定规则下的数字排列问题。 #### 题目描述 给定数字1、2、2、3、4、5,编写一个Java程序,打印出所有不同的排列,但需满足以下条件: - “4”不能出现在第三位; - “3...
Java应聘人员考题通常会涵盖广泛的...通过这两个文档——"奥尊JAVA开发人员招聘考题(笔试部分).doc"和"奥尊JAVA开发人员招聘考题(机试部分).doc",应聘者可以深入理解和实践这些Java核心概念,提升自己的竞争力。
这里的"名企笔试相关试题(IT类)"暗示了这份PDF可能包含了一系列知名IT公司的笔试题目,这些题目可能是过往的真实考题或者是模拟题,旨在帮助求职者准备和熟悉可能遇到的挑战。这些试题可能涵盖编程语言、数据结构...
在Android开发的面试或招聘考试中,了解并熟练掌握Display类的工作原理和用法是至关重要的,因为它直接影响到应用程序的用户体验和性能。通过在线云笔试平台,如http://www.101test.com,可以进行模拟测试和练习,...
过滤器作为Struts2的入口点,负责初始化和管理整个框架的生命周期,而拦截器则承担着处理用户请求的关键职责,它们通过对请求进行预处理、调用业务逻辑以及后处理等步骤,确保了流程的高效与有序。 构建Struts2应用...
样题中的初级题——**从考试成绩中划出及格线**,需要找到满足条件的最低及格分数,这涉及到数值比较和百分比计算。 中级题——**亮着电灯的盏数**,是一个典型的约瑟夫问题变形,可以通过模运算和计数来确定最后亮...