Java日期工具类LocalDate

Java日期工具类LocalDate

  • 嘚吧嘚
    • java.util.Date
    • Java8新增日期类
    • 时区
  • LocalDate - API
    • 创建日期
    • 获取年月日
    • 修改年月日
    • 日期比较

嘚吧嘚

java.util.Date

在Java8之前通常会使用Date结合SimpleDateFormat、Calender来处理时间和日期的相关需求。

1、可读性差、易用性差、使用起来冗余繁琐
2、java.util.Date 是非线程安全的
3、java.util.Date 存在千年虫问题、并且不支持国际化和时区、故大部分方法被声明为过时、不建议再使用
4、java.util和java.sql两包中都有Date类,设计上并不合理

Java8新增日期类

Java8新增的日期类主要有三个:

LocalDate:表示日期(年月日)
LocalTime :表示时间(时分秒)
LocalDateTime:表示日期 + 时间(年月日时分秒),是java8最常用的日期类

这些类使用了final来修饰,使得这些类是不可变的,一旦实例化,值就固定了,有点类似于String类。
因此它们都是线程安全的。

时区

在本文中会用到时区,所以给大家介绍几个常用的时区。

函数声明描述
ZoneId.of(“Asia/Shanghai”)上海
ZoneId.of(“Asia/Chongqing”)重庆
ZoneId.of(“Asia/Chungking”)重庆
ZoneId.of(“Asia/Hong_Kong”)香港
ZoneId.of(“Hongkong”)香港

可以使用下面代码查看所有时区。

Set<String> availableZoneIds = ZoneId.getAvailableZoneIds();
System.out.println(availableZoneIds.size());
availableZoneIds.forEach(System.out::println);

在这里插入图片描述
本篇文章先梳理一下LocalDate的相关内容。

LocalDate - API

创建日期

函数声明描述
static LocalDateTime now()获取默认时区的当前日期时间
LocalDate of(int year, int month, int dayOfMonth)根据指定年月日创建LocalDate对象
static LocalDate now(ZoneId zone)获取指定时区的当前日期对象
static LocalDate now(Clock clock)从指定时钟获取当前日期对象
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
// 获取当前日期
LocalDate now = LocalDate.now();
// 指定时区
LocalDate now2 = LocalDate.now(ZoneId.of("Asia/Shanghai"));
LocalDate now3 = LocalDate.now(ZoneId.of("Canada/Yukon"));
// 指定时钟
LocalDate now4 = LocalDate.now(Clock.systemDefaultZone());
// 指定时间
LocalDate date1 = LocalDate.of(1999, 12, 5);
System.out.println("now : " + now.format(formatter));
System.out.println("now2 : " + now2.format(formatter));
System.out.println("now3 : " + now3.format(formatter));
System.out.println("now4 : " + now4.format(formatter));
System.out.println("date1 : " + date1.format(formatter));

在这里插入图片描述

获取年月日

函数声明描述
int getYear()获取年份
Month getMonth()获取月份,返回值为月份的枚举
int getMonthValue()获取月份,返回值为int类型月份
DayOfWeek getDayOfWeek()获取日期是星期几
int getDayOfMonth()获取日期在该月是第几天
int getDayOfYear()获取日期在该年是第几天
int lengthOfMonth()本月份总天数
int lengthOfYear()本年度总天数
long toEpochDay()与时间纪元(1970年1月1日)相差的天数
LocalDate now = LocalDate.now();
System.out.println("getYear : " + now.getYear());
System.out.println("getMonth : " + now.getMonth());
System.out.println("getMonthValue : " + now.getMonthValue());
System.out.println("getDayOfMonth : " + now.getDayOfMonth());
System.out.println("getDayOfWeek : " + now.getDayOfWeek());
System.out.println("getDayOfYear : " + now.getDayOfYear());
System.out.println("lengthOfMonth : " + now.lengthOfMonth());
System.out.println("lengthOfYear : " + now.lengthOfYear());
System.out.println("toEpochDay : " + now.toEpochDay());

在这里插入图片描述

修改年月日

函数声明描述
LocalDate plusYears(long years)增加年
LocalDate plusMonths(long months)增加月份
LocalDate plusWeeks(long weeks)增加周
LocalDate plusDays(long days)增加日
LocalDate minusYears(long years)减少年
LocalDate minusMonths(long months)减少月份
LocalDate minusWeeks(long weeks)减少周
LocalDate minusDays(long days)减少日
LocalDate withDayOfMonth(int dayOfMonth)替换月份中的第几天(1-31)
LocalDate withDayOfYear(int dayOfYear)替换年份中的第几天(1-366)
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
// 获取当前日期
LocalDate now = LocalDate.now();
System.out.println("now : " + now.format(formatter));System.out.println("plusDays : " + now.plusDays(1));
System.out.println("minusDays : " + now.minusDays(-1));
System.out.println("-------------------------------------");
System.out.println("plusDays : " + now.plusDays(-2));
System.out.println("minusDays : " + now.minusDays(2));System.out.println("withDayOfMonth : " + now.withDayOfMonth(2));
System.out.println("withDayOfYear : " + now.withDayOfYear(36));

plusXxx是增加时间,minusXxx是减少时间,但查看源码可以发现minusXxx还是用的plusXxx,所以这两类方法传参可为正数,也可为负数。正负号相同、数字相同时效果相反。
在这里插入图片描述

日期比较

函数声明描述
boolean isEqual(ChronoLocalDate other)判断日期时间是否相等
boolean isAfter(ChronoLocalDate other)检查是否在指定日期时间之前
boolean isBefore(ChronoLocalDate other)检查是否在指定日期时间之后
boolean isLeapYear()是否是闰年

在这里插入图片描述
欢迎补充😉。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/585829.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#的checked关键字判断是否溢出

目录 一、定义 二、示例&#xff1a; 三、生成&#xff1a; 一、定义 使用checked关键字处理溢出。 在进行数学运算时&#xff0c;由于变量类型不同&#xff0c;数值的值域也有所不同。如果变量中的数值超出了变量的值域&#xff0c;则会出现溢出情况&#xff0c;出现溢出…

12.21自动售货机,单物品,多物品

自动售货机 if朴素方法 一种思路是用寄存器cnt记录已有的最小单位货币量&#xff0c;这里就是0.5 当d1时&#xff0c;cnt1;d2时&#xff0c;cnt2;d3时&#xff0c;cnt4; timescale 1ns/1ns module seller1(input wire clk ,input wire rst ,input wire d1 ,input wire d2 …

vue3 组件之间传值

vue3 组件之间传值 非常好&#xff0c;为啥突然开这样一篇博文&#xff0c;首先是因为 vue3 是未来发展的趋势。其次&#xff0c;vue 官方已经确认&#xff0c;将于2023年最后一天停止对 vue2 项目的维护&#xff0c;这个是官方发出的通知&#xff0c;并且呢&#xff0c;尤雨溪…

面试算法78:合并排序链表

题目 输入k个排序的链表&#xff0c;请将它们合并成一个排序的链表。 分析&#xff1a;利用最小堆选取值最小的节点 用k个指针分别指向这k个链表的头节点&#xff0c;每次从这k个节点中选取值最小的节点。然后将指向值最小的节点的指针向后移动一步&#xff0c;再比较k个指…

统信UOS及麒麟KYLINOS操作系统上设置GRUB密码

原文链接&#xff1a;给单用户模式上一层保险&#xff01;&#xff01;&#xff01; hello&#xff0c;大家好啊&#xff01;今天我要给大家介绍的是在统信UOS及麒麟KYLINOS操作系统上设置GRUB密码的方法。GRUB&#xff08;GRand Unified Bootloader&#xff09;是Linux系统中的…

利用F12和Fiddler抓包

网络基础 http 而http协议又分为下面的部分,点击具体条目后可以查看详细信息 http请求消息:请求行(请求方法),请求路径,请求头,请求体(载荷) http响应消息:响应行(响应状态码),响应头&#xff0c;响应体 请求行 即请求方法 get post put patch 响应行 即响应码,常见响应状态…

祖先是否安宁,直接关系到个人以及家运哦!

一直以来&#xff0c;中国古代流传下来的思想就认为&#xff0c;祖先安葬在好的风水福地&#xff0c;一定能给子孙后代带来吉祥如意。相反的&#xff0c;假如祖坟风水不好&#xff0c;则会影响到后人的运气&#xff0c;轻者诸事不顺、重者家庭破裂、噩运连连&#xff0c;所以&a…

【C++杂货铺】C++11新特性——lambda

文章目录 一、C98中的排序二、先来看看 lambda 表达式长什么样三、lambda表达式语法3.1 捕捉列表的使用细节 四、lambda 的底层原理五、结语 一、C98中的排序 在 C98 中&#xff0c;如果要对一个数据集合中的元素进行排序&#xff0c;可以使用 std::sort 方法&#xff0c;下面…

二叉树顺序结构与堆的概念及性质(c语言实现堆)

上次介绍了树&#xff0c;二叉树的基本概念结构及性质&#xff1a;二叉树数据结构&#xff1a;深入了解二叉树的概念、特性与结构 今天带来的是&#xff1a;二叉树顺序结构与堆的概念及性质&#xff0c;还会用c语言来实现堆 文章目录 1. 二叉树的顺序结构2.堆的概念和结构3.堆…

推荐几个开源HTTP服务接口快速生成工具

在现在流行微服务、前后端分离软件开发架构下&#xff0c;基于标准RESTful/JSON的HTTP接口已经成为主流。在实际业务中有很多需要快速开发调用数据服务接口的需求&#xff0c;但团队中缺乏专业的后端开发人员&#xff0c;比如&#xff1a; &#xff08;1&#xff09;数据库表已…

PHP开发日志 ━━ 基于PHP和JS的AES相互加密解密方法详解(CryptoJS) 适合CryptoJS4.0和PHP8.0

最近客户在做安全等保&#xff0c;需要后台登录密码采用加密方式&#xff0c;原来用个base64变形一下就算了&#xff0c;现在不行&#xff0c;一定要加密加key加盐~~ 前端使用Cypto-JS加密&#xff0c;传输给后端使用PHP解密&#xff0c;当然&#xff0c;前端虽然有key有盐&…

如何学习计算机编程?零基础入门,轻松成为编程达人!

在这个信息爆炸的时代&#xff0c;计算机编程已经成为一项炙手可热的技能。如果你也对编程充满兴趣&#xff0c;但又不知从何入手&#xff0c;那么本文将为你提供一条通往编程世界的捷径。掌握了这些技巧&#xff0c;相信你一定能够轻松成为编程达人&#xff01; 一、选择合适…

lag-llama源码解读(Lag-Llama: Towards Foundation Models for Time Series Forecasting)

Lag-Llama: Towards Foundation Models for Time Series Forecasting 文章内容&#xff1a; 时间序列预测任务&#xff0c;单变量预测单变量&#xff0c;基于Llama大模型&#xff0c;在zero-shot场景下模型表现优异。创新点&#xff0c;引入滞后特征作为协变量来进行预测。 获得…

爬虫工作量由小到大的思维转变---<第三十五章 Scrapy 的scrapyd+Gerapy 部署爬虫项目>

前言: 项目框架没有问题大家布好了的话,接着我们就开始部署scrapy项目(没搭好架子的话,看我上文爬虫工作量由小到大的思维转变---&#xff1c;第三十四章 Scrapy 的部署scrapydGerapy&#xff1e;-CSDN博客) 正文: 1.创建主机: 首先gerapy的架子,就相当于部署服务器上的;所以…

Ubuntu 18.04搭建RISCV和QEMU环境

前言 因为公司项目代码需要在RISCV环境下测试&#xff0c;因为没有硬件实体&#xff0c;所以在Ubuntu 18.04上搭建了riscv-gnu-toolchain QEMU模拟器环境。 安装riscv-gnu-toolchain riscv-gnu-toolchain可以从GitHub上下载源码编译&#xff0c;地址为&#xff1a;https://…

大华主动注册协议介绍

一、大华主动注册协议介绍 前面写了一篇文章&#xff0c;介绍一些设备通过大华主动注册协议接入到AS-V1000的文章&#xff0c;很多问我关于大华主动注册协议的相关知识。 由于大华主动注册协议是一种私有协议&#xff0c;通常不对外公开详细的协议规范和技术细节。因此…

C++ Primer Plus----第十二章--类和动态内存分布

本章内容包括&#xff1a;对类成员使用动态内存分配&#xff1b;隐式和显式复制构造函数&#xff1b;隐式和显式重载赋值运算符&#xff1b;在构造函数中使用new所必须完成的工作&#xff1b;使用静态类成员&#xff1b;将定位new运算符用于对象&#xff1b;使用指向对象的指针…

ssm基于web的志愿者管理系统的设计与实现+vue论文

摘 要 使用旧方法对志愿者管理系统的信息进行系统化管理已经不再让人们信赖了&#xff0c;把现在的网络信息技术运用在志愿者管理系统的管理上面可以解决许多信息管理上面的难题&#xff0c;比如处理数据时间很长&#xff0c;数据存在错误不能及时纠正等问题。这次开发的志愿者…

main参数传递、反汇编、汇编混合编程

week03 一、main参数传递二、反汇编三、汇编混合编程 一、main参数传递 参考 http://www.cnblogs.com/rocedu/p/6766748.html#SECCLA 在Linux下完成“求命令行传入整数参数的和” 注意C中main: int main(int argc, char *argv[]), 字符串“12” 转为12&#xff0c;可以调用atoi…

两种汇编的实验

week04 一、汇编-1二、汇编-2 一、汇编-1 1 通过输入gcc -S -o main.s main.c -m32 将下面c程序”week0401学号.c“编译成汇编代码 int g(int x){ return x3; } int f(int x){ int i 学号后两位&#xff1b; return g(x)i; } int main(void){ return f(8)1; } 2. 删除汇编代码…