> 文档中心 > 新星计划Day 1 b站尚硅谷java常用类 479p-489p

新星计划Day 1 b站尚硅谷java常用类 479p-489p


479p 课后练习1

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

public void testExer() throws ParseException{   String birth="2020-09-08";   SimpleDateFormat sdf1=new SimpleDateFormat("yyyy-MM-dd");   Date date=sdf1.parse(birth);   java.sql.Date birthDate=new java.sql.Date(date.getTime());   System.out.println(birthDate);  }}

 

 

480 课后练习2

三天打鱼两天晒网

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

方式二:1999-01-01---2019-12-31+2020-01-01---2020-09-08

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

Calendar是一个抽象基类,主用用于完成日期字段之间相互操作的功能。
获取Calendar实例的方法
使用Calendar.getInstance()方法
调用它的子类GregorianCalendar的构造器。
一个Calendar的实例是系统时间的抽象表示,通过get(intfield)方法来取得想要的时间信息。比如YEAR、MONTH、DAY_OF_WEEK、HOUR_OF_DAY 、MINUTE、SECOND
public void set(intfield,intvalue)
public void add(intfield,intamount)
public final Date getTime()
public final void setTime(Date date)
注意:
获取月份时:一月是0,二月是1,以此类推,12月是11
获取星期时:周日是1,周二是2,。。。。周六是7
 

public void testCalendar(){    //1.实例化    Calendar calendar=Calendar.getInstance();    //2.常用方法    //get()    int days=calendar.get(Calendar.DAY_OF_MONTH);    System.out.println(days);    System.out.println(calendar.get(Calendar.DAY_OF_YEAR));    //set()    calendar.set(Calendar.DAY_OF_MONTH,22);    days = calendar.get(Calendar.DAY_OF_MONTH);    System.out.println(days);   //22    //add()    calendar.add(Calendar.DAY_OF_MONTH,3);    days = calendar.get(Calendar.DAY_OF_MONTH);    System.out.println(days);   //22    //getTime():日历类---date    Date date=calendar.getTime();    System.out.println(days);     //setTime():Date---日历类    Date date1=new Date();    calendar.setTime(date1);    days = calendar.get(Calendar.DAY_OF_MONTH);    System.out.println(days); 

482 jdk8中日期时间API的介绍

如果我们可以跟别人说:“我们在1502643933071见面,别晚了!”那么就再简单不过了。但是我们希望时间与昼夜和四季有关,于是事情就变复杂了。JDK 1.0中包含了一个java.util.Date类,但是它的大多数方法已经在JDK 1.1引入Calendar类之后被弃用了。而Calendar并不比Date好多少。它们面临的问题是:

可变性:像日期和时间这样的类应该是不可变的。
偏移性:Date中的年份是从1900开始的,而月份都从0开始。
格式化:格式化只对Date有用,Calendar则不行。
此外,它们也不是线程安全的;不能处理闰秒等。
 

import org.junit.Test;import java.util.Date;/** * jdk 8中日期时间API的测试 * */public class JDK8DateTimeTest {    @Test    public void testDate(){ //偏移量 Date date1 = new Date(2020,9,8); System.out.println(date1);  //Fri Oct 08 00:00:00 CST 3920 Date date2 = new Date(2020 - 1900,9 - 1,8); System.out.println(date2); //Tue Sep 08 00:00:00 CST 2020    }}

第三次引入的API是成功的,并且Java 8中引入的java.time API 已经纠正了过去的缺陷,将来很长一段时间内它都会为我们服务。

Java 8 吸收了Joda-Time 的精华,以一个新的开始为Java 创建优秀的API。新的java.time 中包含了所有关于本地日期(LocalDate)、本地时间(LocalTime)、本地日期时间(LocalDateTime)、时区(ZonedDateTime)和持续时间(Duration)的类。历史悠久的Date 类新增了toInstant()方法,用于把Date 转换成新的表示形式。这些新增的本地化时间日期API 大大简化了日期时间和本地化的管理。

java.time–包含值对象的基础包
java.time.chrono–提供对不同的日历系统的访问java.time.format–格式化和解析时间和日期java.time.temporal–包括底层框架和扩展特性java.time.zone–包含时区支持的类

说明:大多数开发者只会用到基础包和format包,也可能会用到temporal包。因此,尽管有68个新的公开类型,大多数开发者,大概将只会用到其中的三分之一。
 

483 LocalDate、LocalTime、LocalDateTime的使用

LocalDate、LocalTime、LocalDateTime类是其中较重要的几个类,它们的实例是不可变的对象,分别表示使用ISO-8601日历系统的日期、时间、日期和时间。它们提供了简单的本地日期或时间,并不包含当前的时间信息,也不包含与时区相关的信息。
LocalDate代表IOS格式(yyyy-MM-dd)的日期,可以存储生日、纪念日等日期。
LocalTime表示一个时间,而不是日期。
LocalDateTime是用来表示日期和时间的,这是一个最常用的类之一。
注:ISO-8601日历系统是国际标准化组织制定的现代公民的日期和时间的表示法,也就是公历。
 

public void test1(){   //now():获取当前的日期,时间,日期+时间   LocalDate localDate=LocalDate.now();   LocalTime localTime=LocalTime.now();   LocalDateTime localDateTime=LocalDateTime.now();   System.out.println(localDate);   System.out.println(localTime);   System.out.println(localDateTime);   //of():设置指定的年,月,日,时,分,秒。没有偏移量   LocalDateTime localDateTime1 = LocalDateTime.of(2020, 10, 6, 13, 23, 43);   System.out.println(localDateTime1);   //getXxx():获取相关的属性 System.out.println(localDateTime.getDayOfMonth()); System.out.println(localDateTime.getDayOfWeek()); System.out.println(localDateTime.getMonth()); System.out.println(localDateTime.getMonthValue()); System.out.println(localDateTime.getMinute());   //体现不可变性 //withXxx():设置相关的属性 LocalDate localDate1 = localDate.withDayOfMonth(22); System.out.println(localDate); System.out.println(localDate1); LocalDateTime localDateTime2 = localDateTime.withHour(4); System.out.println(localDateTime); System.out.println(localDateTime2); //不可变性 LocalDateTime localDateTime3 = localDateTime.plusMonths(3); System.out.println(localDateTime); System.out.println(localDateTime3); LocalDateTime localDateTime4 = localDateTime.minusDays(6); System.out.println(localDateTime); System.out.println(localDateTime4);    }}

484 Instant类的使用 

Instant:时间线上的一个瞬时点。这可能被用来记录应用程序中的事件时间戳。
在处理时间和日期的时候,我们通常会想到年,月,日,时,分,秒。然而,这只是时间的一个模型,是面向人类的。第二种通用模型是面向机器的,或者说是连续的。在此模型中,时间线中的一个点表示为一个很大的数,这有利于计算机处理。在UNIX中,这个数从1970年开始,以秒为的单位;同样的,在Java中,也是从1970年开始,但以毫秒为单位。
java.time包通过值类型Instant提供机器视图,不提供处理人类意义上的时间单位。Instant表示时间线上的一点,而不需要任何上下文信息,例如,时区。概念上讲,它只是简单的表示自1970年1月1日0时0分0秒(UTC)开始的秒数。因为java.time包是基于纳秒计算的,所以Instant的精度可以达到纳秒级。

public void test2(){ //now():获取本初子午线对应的标准时间 Instant instant = Instant.now(); System.out.println(instant);    //2020-05-10T09:55:55.561Z //添加时间的偏移量 OffsetDateTime offsetDateTime = instant.atOffset(ZoneOffset.ofHours(8));//东八区 System.out.println(offsetDateTime); //2020-05-10T18:00:00.641+08:00 //toEpochMilli():获取自1970年1月1日0时0分0秒(UTC)开始的毫秒数  ---> Date类的getTime() long milli = instant.toEpochMilli(); System.out.println(milli);  //1589104867591 //ofEpochMilli():通过给定的毫秒数,获取Instant实例  -->Date(long millis) Instant instant1 = Instant.ofEpochMilli(1550475314878L); System.out.println(instant1);   //2019-02-18T07:35:14.878Z    }

485 DateTimeFormatter的使用 

java.time.format.DateTimeFormatter 类:该类提供了三种格式化方法:

预定义的标准格式。如:ISO_LOCAL_DATE_TIME;ISO_LOCAL_DATE;ISO_LOCAL_TIME
本地化相关的格式。如:ofLocalizedDateTime(FormatStyle.LONG)
自定义的格式。如:ofPattern(“yyyy-MM-dd hh:mm:ss”)

 

//重点: 方式三:自定义的格式。如:ofPattern(“yyyy-MM-dd hh:mm:ss”) DateTimeFormatter formatter3 = DateTimeFormatter.ofPattern("yyyy-MM-dd hh:mm:ss"); //格式化 String str4 = formatter3.format(LocalDateTime.now()); System.out.println(str4);//2020-05-10 06:26:40 //解析 TemporalAccessor accessor = formatter3.parse("2020-05-10 06:26:40"); System.out.println(accessor);

 486 其他日期相关的API的使用

ZoneId:该类中包含了所有的时区信息,一个时区的ID,如Europe/Paris
ZonedDateTime:一个在ISO-8601日历系统时区的日期时间,如2007-12-03T10:15:30+01:00Europe/Paris。
其中每个时区都对应着ID,地区ID都为“{区域}/{城市}”的格式,例如:Asia/Shanghai等
Clock:使用时区提供对当前即时、日期和时间的访问的时钟。
持续时间:Duration,用于计算两个“时间”间隔
日期间隔:Period,用于计算两个“日期”间隔
TemporalAdjuster : 时间校正器。有时我们可能需要获取例如:将日期调整到“下一个工作日”等操作。
TemporalAdjusters : 该类通过静态方法(firstDayOfXxx()/lastDayOfXxx()/nextXxx())提供了大量的常用TemporalAdjuster 的实现。

 488 Java比较器概述

Java中的对象,正常情况下,只能进行比较:==或 != 。不能使用 >或<的,但是在开发场景中,我们需要对多个对象进行排序,言外之意,就需要比较对象的大小。 如何实现?使用两个接口中的任何一个:Comparable或 Comparator

Java实现对象排序的方式有两种:
自然排序:java.lang.Comparable
定制排序:java.util.Comparator
 

489 Comparable自然排序举例

 Comparable接口的使用举例:  自然排序
     * 1.像String、包装类等实现了Comparable接口,重写了compareTo(obj)方法,给出了比较两个对象大小的方式。
     * 2.像String、包装类重写compareTo()方法以后,进行了从小到大的排列
     * 3. 重写compareTo(obj)的规则:
     *    如果当前对象this大于形参对象obj,则返回正整数,
     *    如果当前对象this小于形参对象obj,则返回负整数,
     *    如果当前对象this等于形参对象obj,则返回零。