【JavaSE】day03_Date、SimpleDateFormat、Calendar、Collection

2024-06-14 01:32

本文主要是介绍【JavaSE】day03_Date、SimpleDateFormat、Calendar、Collection,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【JavaSE】day03_Date、SimpleDateFormat、Calendar、Collection


1.Date及其常用API

1)JAVA 中的时间

Java中的时间使用标准类库的Date类表示,是用距离一个固定时间点的毫秒数(可正可负,long类型)表达一个特定的时间点。

固定的时间点叫纪元(epoch),是UTC时间1970年 1月 1日 00:00:00。

UTC(Universal Time Coordinated世界调整时间)与GMT(Greenwich Mean Time格林威治时间)一样,是一种具有实际目的的科学标准时间。


2)Date类简介

java.util.Date 类封装日期及时间信息。

Date类的大多数用于进行时间分量计算的方法已经被Calendar取代。


3)setTime与getTime方法

void setTime(long time):

该方法用于为一个Date对象设置其需要表示的时间,该参数为一个long值,其含义是需要表示的这个时间点距离1970年1月1日 00:00:00之间的毫秒差。

long getTime()

该方法用于获取一个Date对象所表示的时间点,该返回值为一个long值,表示该时间点距离1970年1月1日 00:00:00之间的毫秒差。


4) Date 重写 toString方法

Date重写了toString()方法,用一个字符串来描述当前Date对象所表示的时间。

格式如下:
    Mon Feb 17 15:36:55 CST 2014

代码演示:

package day03;import java.util.Date;/*** java.util.Date* 其每一个实例用于表示一个时间点* 内部维护一个long值,该值是从UTC时间的1970/01/01 00:00:00* 至当前Date表示的时间点之间的毫秒差**/
public class DateDemo01 {public static void main(String[] args) {/** 默认创建出来的Date实例表示当前系统时间*/Date date = new Date();/** Date类重写类toString,只是对于非英语国家来说不是很友好*/System.out.println(date); //Mon Aug 24 21:37:16 CST 2015/** 获取Date内部维护的long值*/long longTime = date.getTime();System.out.println(longTime); //1440423436050//表示明天当前时间longTime += 1000*60*60*24;/** 支持传入long值的构造方法* 创建的Date就表示该long值所表示的时间*/Date tomrrowDate = new Date(longTime);System.out.println(tomrrowDate); //Tue Aug 25 21:37:16 CST 2015/** 也可以在现有的Date对象上调用setTime方法* 将long值传入,使其表示这个时间*/date.setTime(longTime);System.out.println(date); //Tue Aug 25 21:37:16 CST 2015}}

2.SimpleDateFormat

1)SimpleDateFormat简介

SimpleDateFormat 是一个以与语言环境有关的方式来格式化和解析日期的具体类。它允许进行格式化(日期 -> 文本)、解析(文本 -> 日期)和规范化。

简单的说,SimpleDateFormat就是根据一个特定的日期格式在字符串与Date之间相互转换。


2)日期模式匹配字符串

日期模式的匹配字符串如下表:

例如: yyyy年MM月dd日--HH:mm:ss 可以匹配 2014年01月06日--13:22:41


3)将Date格式化为String

将Date格式化为String,我们需要使用SimpleDateFormat提供的方法:

    String format(Date d)

代码演示:

package day03;import java.text.SimpleDateFormat;
import java.util.Date;/*** java.text.SimpleDateFormat* 该类的作用是使用给定的字符串格式在Date与String之间进行转换。* 对于该类,需要掌握:* 1:会写日期格式字符串* 2:记住两个转换方法(String->Date,Date->String)**/
public class SimpleDateFormatDemo01 {public static void main(String[] args) {Date now = new Date();System.out.println(now);/** 2015-08-24 09:50:12* yyyy-MM-dd HH:mm:ss*/SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss E");/** String format(Date date)* 按照创建SimpleDateFormat时指定的日期格式,* 将当前给定的date对象表示的时间转换为字符串。*/String str = sdf.format(now);System.out.println(str);}}


4)将String解析为Date

将String格式化为Date,我们需要使用SimpleDateFormat提供的方法:

    Date parse(String s)


代码演示:

package day03;import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;/**将字符串按照该日期格式解析为Date**/
public class SimpleDateFormatDemo02 {public static void main(String[] args) {String str = "2008-08-08 20:08:08";System.out.println(str);SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");try {/** Date parse(String str)* 将给定的字符串解析为Date对象并返回。*/Date date = sdf.parse(str);System.out.println(date);} catch (ParseException e) {e.printStackTrace();}}}

3.Calendar类

1)Calendar 简介

java.util.Calendar 类用于封装日历信息,其主要作用在于其方法可以对时间分量进行运算。

Calendar是抽象类,其具体子类针对不同国家的日历系统,其中应用最广泛的是GregorianCalendar(格里高里历,即通用的阳历),对应世界上绝大多数国家/地区使用的标准日历系统。


2)getInstance()方法

Calendar是抽象类,其提供了一个工厂方法:Calendar getInstance()。该方法可以根据当前系统所在地区获取一个适当的Calendar的子类实现。

在实际开发中,也推荐使用该方法来实例化Calendar的对象。


3)setTime与getTime方法

Calendar的void setTime(Date date),允许我们为Calendar设置Date对象所表示的时间。

Calendar的 Date getTime(),允许我们获取一个使用Date对象描述的Calendar所表示的时间。

代码演示:

package day03;import java.util.Calendar;
import java.util.Date;/*** java.util.Calendar* ---public abstract class Calendar* 日历类,用作操作时间。* 常用的是格里高利历法(阳历)* 默认创建出来的Calendar实现类的实例表示当前系统时间**/
public class CalendarDemo01 {public static void main(String[] args) {/** Calendar的getInstance可以根据当前系统所在地区* 创建合适的实现类,通常是格里高利历法。*/Calendar calendar = Calendar.getInstance();/** 不能直观看到具体表示的时间。*/System.out.println(calendar);/** Calendar -> Date* * Date getTime()* Calendar提供的getTime方法可以将其表示的时间以Date形式返回。*/Date date = calendar.getTime();System.out.println(date);/** Date -> Calendar* * void setTime(Date date)* Calendar提供了一个setTime()方法,可以使当前* Calendar表示给定的date所表示的时间。*/Date now = new Date();calendar.setTime(now);System.out.println(calendar);}}

4)设置日期及时间分量

Calendar提供了一种通用的设置时间的方式:

    void set(int field,int value)

该方法可以通过对不同的时间分量分别设置不同的值。Calendar对不同的时间分量提供了相应的常量,我们在使用set方法设置时,第一个参数就应当使用对应的常量作为时间分量。

代码演示:

package day03;import java.util.Calendar;/*** Calendar提供类一个set方法,允许我们对当前Calendar* 的各个时间分量进行单独设定。**/
public class CalendarSet {public static void main(String[] args) {Calendar calendar = Calendar.getInstance();System.out.println(calendar.getTime());/** 设置各个时间分量,* 使其表示:2008/08/08 20:08:08* 需要注意。设置了某个时间分量的值可能会影响其他时间分量的值。* 例如:设置了年、月、日可能会将星期改变。*///设置年份calendar.set(Calendar.YEAR,2008);//设置月份//月份从0开始,有常量对应。0表示1月。。。calendar.set(Calendar.MONTH,7);//设置日//Calendar.DATE==Calendar.DAY_OF_MONTHcalendar.set(Calendar.DAY_OF_MONTH,8);//设置小时//Calendar.HOUR_OF_DAY :24小时制//Calendar.HOUR        :12小时制calendar.set(Calendar.HOUR_OF_DAY,20);//设置分钟calendar.set(Calendar.MINUTE,8);//设置秒calendar.set(Calendar.SECOND,8);System.out.println(calendar.getTime());}}

5) 获取时间分量对应的值

Calendar提供了一种通用的获取时间分量的方式:

    int get(int field)

该方法可以通过对不同的时间分量获取相应的值。Calendar对不同的时间分量提供了相应的常量,我们在使用get方法获取时,参数就应当使用对应的常量作为时间分量。


6)getActualMaximum方法

   int getActualMaximum(int field)方法用于获取给定时间分量所允许的最大值。

代码演示:

package day03;import java.util.Calendar;/*** Calendar提供了一个get方法,可以获取给定的时间分量所对应的值。**/
public class CalendarGet {public static void main(String[] args) {Calendar calendar = Calendar.getInstance();//获取年int year = calendar.get(Calendar.YEAR);//获取月,从0开始int month = calendar.get(Calendar.MONTH)+1;//获取日int day = calendar.get(Calendar.DATE);		System.out.println(year+"-"+month+"-"+day);//获取星期,每周第一天从星期日开始(1表示周日)int week = calendar.get(Calendar.DAY_OF_WEEK);System.out.println(week==1?7:week-1);/** int getActualMaximum(int field)* Calendar提供了一个方法,可以获取给定的时间分量* 在当前Calendar表示的日期中所允许的最大值。* 查看当月的月底--Calendar.DAY_OF_MONTH*/int days = calendar.getActualMaximum(Calendar.DAY_OF_MONTH);System.out.println("这个月:"+days+"天");/** 今年多少天?--Calendar.DAY_OF_YEAR*/days = calendar.getActualMaximum(Calendar.DAY_OF_YEAR);System.out.println("今年共:"+days+"天");}}

7) add方法

Calendar还允许我们使用统一的方式来对某个时间分量的值进行计算。我们需要使用方法

    void add(int field,int amount)

该方法可以为某个时间分量的值加上给定的值,若想减去给定的值,那么传入的值需要是负数即可。并且计算后会自动进行相应的进位,例如若当前为月底,那么加一天后,为下个月的月初,而月就会进位。

package day03;import java.util.Calendar;/*** Calendar提供了一个add方法,用于计算时间。* void add(int field,int value)* 对于给定的时间分量加上给定的值,若value为负数,* 则减去指定的值。**/
public class CalendarAdd {public static void main(String[] args) {Calendar calendar = Calendar.getInstance();//calendar.add(Calendar.YEAR,1);System.out.println(calendar.getTime());/** 查看3年零2个月又25天是那天?*/calendar.add(Calendar.YEAR,3);calendar.add(Calendar.MONTH,2);calendar.add(Calendar.DAY_OF_YEAR,25); //可能会跨年,故用DAY_OF_YEAR//calendar.add(Calendar.DATE,25);System.out.println(calendar.getTime());//减去4年calendar.add(Calendar.YEAR,-4);System.out.println(calendar.getTime());}}

4.Collection

java提供了一种可以存数一组数据的数据结构,其提供了丰富的方法,在实际开发中往往比数组使用的广泛。这种数据结构成为集合:Collection。

Collection是一个接口,其定义了集合的相关功能方法。

1) List和Set

Collection派生出了两个子接口,一个是List另一个则是Set。

List:称为可重复集,顾名思义,该集合中是允许存放重复元素的,那么何为重复元素?重复元素指的并非是同一个元素,而是指equals方法比较为true的元素。

Set:称为不可重复集,所以,该集合中是不能将相同的元素存入集合两次,同List,这里相同指的也是两个元素的equals比较结果为true。


2) add()、size()、clear()、isEmpty()方法

Collection定义了一个add方法用于向集合中添加新元素。 该方法定义为:

boolean add(E e)

该方法会将给定的元素添加进集合,若添加成功则返回true,否则返回false。

size方法用于获取当前集合中的元素总数。该方法定义为:int size()

clear方法用于清空集合。该方法定义为:void clear()

isEmpty方法用于判断当前集合中是否不 包含元素。该方法定义为:boolean isEmpty()

代码演示:

package day03;import java.util.ArrayList;
import java.util.Collection;/*** java.util.Collection* 集合,用于存放一组元素。* 提供类若干功能,比数组使用方便。**/
public class CollectionDemo01 {public static void main(String[] args) {Collection c = new ArrayList();/** boolean add(E e)* 将当前集合中添加给定的元素* 若成功添加则返回true*/c.add("one");c.add("two");c.add("three");c.add("four");/** int size()* 获取当前集合中的元素个数*/System.out.println("size:"+c.size()); //size:4/** boolean isEmpty()* 判断当前集合是否不包含任何元素* 当集合中没有元素时返回true*/boolean b = c.isEmpty();System.out.println(b); //false/** void clear()* 清空集合元素*/c.clear();System.out.println("size:"+c.size()); //size:0System.out.println(c.isEmpty()); //true}}

3)contains方法

boolean contains(Object o)

该方法会用于判断给定的元素是否被包含在集合中。若包含则返回true,否则返回false。

这里需要注意的是,集合在判断元素是否被包含在集合中是使用元素的equals的比较结果。

(o==null ? e==null : o.equals(e)) 其中e是集合中的元素。

代码演示:

package day03;import java.util.ArrayList;
import java.util.Collection;/*** 判断集合是否含有给定的元素**/
public class CollectionDemo02 {public static void main(String[] args) {Collection c = new ArrayList();c.add(new Aoo("zhangsan",21));c.add(new Aoo("lisi",22));c.add(new Aoo("wangwu",23));/** 集合的toString格式* [元素1.toString(),元素2.toString()...]*/System.out.println(c); //[zhangsan,21, lisi,22, wangwu,23]Aoo a = new Aoo("zhangsan",28);/** boolean contains(E e)* 判断当前集合是否包含给定元素,包含则返回true* 判断依据是看给定的元素与集合中现有的元素是否* 存在equals比较为true的,有则认为包含!*/boolean contains = c.contains(a);System.out.println("contains:"+contains); //contains:true}}


4)集合持有对象的引用

集合中存储的都是引用类型的元素,那么引用类型变量实际上存储的是对象的“地址”,所以实际上集合只存储了元素对象在堆中的地址。而并不是将对象本身存入了集合中。

代码演示:

package day03;import java.util.ArrayList;
import java.util.Collection;public class CollectionDemo03 {public static void main(String[] args) {Collection c = new ArrayList();Aoo o = new Aoo("zhangsan",23);c.add(o);System.out.println(c); //[zhangsan,23]o.setName("lisi");System.out.println(c); //[lisi,23]}}


这篇关于【JavaSE】day03_Date、SimpleDateFormat、Calendar、Collection的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1059000

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定