JDK 8之前日期和时间的API测试

JDK 8之前日期和时间的API测试

java.util.Date类(范围大) java.sql.Date类

``
java.util.Date类(范围大)
|—java.sql.Date类

1.两个构造器的使用
>构造器一:Date():创建一个对应当前时间的Date对象
>构造器二:创建指定毫秒数的Date对象
2.两个方法的使用
>toString():显示当前的年、月、日、时、分、秒
>getTime():获取当前Date对象对应的毫秒数。(时间戳)

  1. java.sql.Date对应着数据库中的日期类型的变量

    如何实例化
    如何将java.util.Date对象转换为java.sql.Date对象
    ``

代码:
 @Test
    public void test2(){
        //构造器一:Date():创建一个对应当前时间的Date对象
        Date date1 = new Date();
        System.out.println(date1.toString());//Sat Feb 16 16:35:31 GMT+08:00 2019

        System.out.println(date1.getTime());//1550306204104

        //构造器二:创建指定毫秒数的Date对象
        Date date2 = new Date(155030620410L);
        System.out.println(date2.toString());

        //创建java.sql.Date对象
        java.sql.Date date3 = new java.sql.Date(35235325345L);
        System.out.println(date3);//1971-02-13

        //如何将java.util.Date对象转换为java.sql.Date对象
        //情况一:
//        Date date4 = new java.sql.Date(2343243242323L);
//        java.sql.Date date5 = (java.sql.Date) date4;
        //情况二:
        Date date6 = new Date();
        java.sql.Date date7 = new java.sql.Date(date6.getTime());


    }

    //1.System类中的currentTimeMillis()
    @Test
    public void test1(){
        long time = System.currentTimeMillis();
        //返回当前时间与1970年1月1日0时0分0秒之间以毫秒为单位的时间差。
        //称为时间戳
        System.out.println(time);
    }

SimpleDateFormat的使用:

SimpleDateFormat对日期Date类的格式化和解析

使用默认的构造器

``
1.两个操作:
1.1 格式化:日期 —>字符串
1.2 解析:格式化的逆过程,字符串 —> 日期

2.SimpleDateFormat的实例化
``

//实例化SimpleDateFormat:使用默认的构造器
SimpleDateFormat sdf = new SimpleDateFormat();
//格式化:日期 --->字符串
Date date = new Date();
System.out.println(date);//Sun Jun 06 13:31:00 CST 2021
String format = sdf.format(date);//返回的是字符串
System.out.println(format);//2021/6/6 下午1:29(字符串)
//解析:格式化的逆过程,字符串 ---> 日期
String str = "19-12-18 上午11:43";
Date date1 = sdf.parse(str);
System.out.println(date1);//Sun Jun 06 13:31:00 CST 2021
使用带参数的构造器(指定方式格式化和解析)
不常使用
SimpleDateFormat sdf1 = new SimpleDateFormat("yyyyy.MMMMM.dd GGG hh:mm aaa");//一般不用
常使用
SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
//格式化
System.out.println(format1);//2019-02-18 11:48:27
//解析:要求字符串必须是符合SimpleDateFormat识别的格式(通过构造器参数体现),
//否则,抛异常(原因是对你自己写的东西的不识别)
Date date2 = sdf1.parse("2020-02-18 11:48:27");
System.out.println(date2);
总结:parse解析可以是识别的

System.out.println(date1.getTime());//1578413340000(可以被数据库中的date识别)

String birth="2020-09-08";
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-mm-dd");
Date date1=simpleDateFormat.parse(birth);
System.out.println(date1);//Wed Jan 08 00:09:00 CST 2020
练习:

练习一:字符串"2020-09-08"转换为java.sql.Date

@Test
public void testExer() throws ParseException {

    String birth="2020-09-08";
    SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-mm-dd");
    			//带有参数的构造器SimpleDateFormat对日期Date类的格式化和解析
    Date date1=simpleDateFormat.parse(birth);
    			//把数据给date1;
    System.out.println(date1);
					//输出Wed Jan 08 00:09:00 CST 2020
    java.sql.Date date2=new java.sql.Date(date1.getTime());
    			//getTime()-->转化为可以被识别的一串数字1578413340000
    			//数据库中变量在接受一下
    System.out.println(date2);

}
练习二:“三天打渔两天晒网” 1990-01-01 xxxx-xx-xx 打渔?晒网?
举例:2020-09-08 ? 总天数

总天数 % 5 == 1,2,3 : 打渔
总天数 % 5 == 4,0 : 晒网

总天数的计算?
方式一:( date2.getTime() - date1.getTime()) / (1000 * 60 * 60 * 24) + 1
方式二:1990-01-01  --> 2019-12-31  +  2020-01-01 -->2020-09-08

Calendar日历类(抽象类)的使用

1.实例化:

//1.实例化 //方式一:创建其子类(GregorianCalendar)的对象 //方式二:调用其静态方法getInstance() //常用 Calendar calendar = Calendar.getInstance();

2.常用方法get() ,set() ,add() ,getTime() ,setTime()

get()
int days = calendar.get(Calendar.DAY_OF_MONTH);//当前这个月的第多少天 //18(当天18号)
set()
calendar.set(Calendar.DAY_OF_MONTH,22);//对本身进行修改 修改本月是第22天 //22
add()
calendar.add(Calendar.DAY_OF_MONTH,3);//25
days = calendar.get(Calendar.DAY_OF_MONTH);
System.out.println(days);
getTime()日历类—> Date
Date date = calendar.getTime();
System.out.println(date);
setTime():Date —> 日历类
Date date1 = new Date();
calendar.setTime(date1);
days = calendar.get(Calendar.DAY_OF_MONTH);
System.out.println(days);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值