Date类
从1970.1.1.0点开始到某个时刻的毫秒数,类型是long
1970年之前用负数表示
toGMTString()不建议使用
getTime() 返回时间的毫秒数
setTime() 设置时间,毫秒数
DateFormat(父类) , SimpleDateFormat(子类)字符串和时间类的转化
new Date() 返回当前的时间
将时间类转化为字符串:
DateFormat df = new SimpleDateFormat("yyyy年MM月dd日");
Date d = new Date(1234567L);
String str = df.format(d);
print;
yyyy-MM-dd hh:mm:ss 年月日时分秒
字符串转化为时间类:
String str2 = "1997-7-7";
DateFormt df2 = new SimpleDateFormt("yyyy-MM-dd");
Date d2 = df2.parse(str2);
字符串中的格式必须和SimDateFormat中的格式相同,否则会报错
Calendar 类(抽象类)–GregorianCalendar(子类)
一月是0 二月是1,12月是11。周日是1,周一是2,周六是7.
创建对象(两种方式):
Calendar c = Calendar.getInstance();
Calendar c = new GregorianCalendar();
常见字段:
YEAR: 当前年份
MONTH: 当前月份(最小值为0)
WEEK_OF_MONTH: 当前时间是当本月中的第几个星期。
WEEK_OF_YEAR: 当前时间是当本年中的第几个星期
DATE: 当前时间是当前年中的第多少天。
DAY_OF_YEAR: 当前时间是当前年中的第多少天。
DAY_OF_MONTH: 指示一个月中的某天(最小值为1)。
DAY_OF_WEEK: 当前时间是一个星期中的第几天。最小值为1,表示周日。
DAY_OF_WEEK_IN_MONTH: 指示当前月中的第几个星期。
HOUR: 指示上午或下午的小时(最大值是12)
HOUR_OF_DAY: 指示一天中的小时(最大值是24)
MINUTE: 当前的分钟值
SECOND: 当前的秒值
MILLISECOND: 当前的毫秒值
常见方法:
setTime(Date date): 用date对象初始化
get(int field): 返回指定日历字段的值
add(int field, int amount): 根据日历的规则,为给定的日历字段添加或减去指定的时间量。
getMaximum(int field): 返回此 Calendar 实例给定日历字段的最大值。
一个简单的日历程序:
源代码如下:
import java.util.*;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
public class TestDate {
public static void main (String [] args){
try {
System.out.println("请输入时间:(YYYY-MM-dd)");
Scanner input = new Scanner(System.in);
String time = input.nextLine();
DateFormat format = new SimpleDateFormat("yyyy-MM-dd");
Date date = format.parse(time);
Calendar c = new GregorianCalendar();
c.setTime(date);
c.set(Calendar.DATE, 1);
System.out.println("日\t一\t二\t三\t四\t五\t六");
for(int j = 1 ; j < c.get(Calendar.DAY_OF_WEEK); j++){
System.out.print("\t");
}
for (int i = 1 ; i < c.getMaximum(Calendar.DATE); i++){
System.out.print(i+"\t");
if(c.get(Calendar.DAY_OF_WEEK)==Calendar.SATURDAY){
System.out.println();
}
c.add(Calendar.DATE, 1);
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}