Java中与时间相关的几个类(Date、Calendar、SimpleDateFormat)

我们平时做项目过程中,很多时候都会与时间、日期打交道,今天我们就来讲讲在Java里面如何较好的使用这些与时间相关的类。希望通过今天的讲解能够使得以后在Java中使用时间相关的操作时能够信手拈来。首先,让我们先看一个例子:

public static void main(String[] args) {
        SimpleDateFormat df = new SimpleDateFormat("yyyy-MMM-dd hh:mm:ss:SS a W E z");
        Date now = new Date();// java.util.Date
        //Date now = new Date(System.currentTimeMillis());  //java.sql.Date
        String time = df.format(now);
        System.out.println(time);
        System.out.println(now.getYear());//通过Date类对象的函数获取时间数据已经过时,而且输出的数据难以理解

        Calendar cal = Calendar.getInstance();
        cal.setTime(now);
        System.out.println(cal.get(Calendar.YEAR));
        System.out.println(cal.get(Calendar.MONTH));//注意,月份范围是:0-11
        System.out.println(cal.get(Calendar.DAY_OF_MONTH));
    }

上面这段code设计到Date、Calendar以及SimpleDateFormat类,输出结果如下:

2016-四月-08 12:30:35:730 上午 2 星期五 CST
116
2016
3
8

如果能够理解上面三个类的使用,在我们平时开放中,处理与时间和日期相关的操作基本上够了。下面我们具体进行讲解:

SimpleDateFormat类

1、在日期类格式化字符串中,一半字母a-z、A-Z都代表着具体的含义,如果使用字母进行非转译输出,需要使用单引号进行输出,例如:‘mm’。下面是格式化字母表代表的含义:
这里写图片描述

我们最开始例子中格式化字符串“yyyy-MMM-dd hh:mm:ss:SS a W E z”代表的时间输出格式为:2016-四月-08 12:30:35:730 上午 2 星期五 CST
2、SimpleDateFormat类中,一般我们使用的函数有两个:
- format(Date date):将日期date对象转换为字符串格式的日期输出。
- parse(String date):将字符串格式的日期转换为日期对象Date进行操作。

Date

对于日期类Date,我们先来看一个例子:

public static void main(String args[]){
        Date date = new Date();
        System.out.println(date.getYear());
    }
输出结果为 :116,  而且getYear()方法已经不再建议使用。于是想到Calendar。

Calendar

首先,我们仍然来看一个例子:

    public static void main(String args[]){
        Date date=new Date();
        Calendar cal=Calendar.getInstance();
        cal.setTime(date);
        System.out.println(cal.get(Calendar.YEAR));
    }
虽然Date类中的getYear()函数很好用,但是已经过时而且被Calendar.get(Calendar.MONTH)取代,所以,在平时的操作中我们一般使用Calendar类来操作日期函数中的各部分数据。
Calendar类中的一些常量如下:
参考资料:

YEAR 这是哪年
MONTH 这是月(从0开始)
WEEK_OF_YEAR 今年的第几星期
WEEK_OF_MONTH 这个月的第几星期(从一开始)
DATE 今天几号
DAY_OF_MONTH 这个月的第几天
DAY_OF_YEAR 这一年的第几天
DAY_OF_WEEK 这周周几(从日开始计算,从1计算)
DAY_OF_WEEK_IN_MONTH 第几周(从第一天开始算一周)

AM_PM 上午还是下午0为上午,1为下午
HOUR 12小时制几点
HOUR_OF_DAY 24小时制几点
MINUTE 多少分
SECOND 多少秒
MILLISECOND 多少毫秒
ZONE_OFFSET 时区
DST_OFFSET

该类的具体使用方法,网络上很多,在此就不再赘述了,而要强调的是,对日期时间各部分的操作我们尽量选择Calendar类来操作,而不是Date类。
参考:http://blog.csdn.net/huaishuming/article/details/24319901

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值