深入了解 kotlinx-datetime:配置与使用指南

深入了解 kotlinx-datetime:配置与使用指南
在Kotlin多平台开发中,处理日期和时间是常见的需求。kotlinx-datetime库提供了强大且简洁的API来帮助开发者应对这一挑战。本文将详细介绍如何配置kotlinx-datetime库,并通过生动的示例演示其核心功能。
一、库的设计原则
kotlinx-datetime 是为了解决开发者日常处理日期和时间的常见问题而设计的。其设计遵循以下原则:
- 实用性:它注重于开发者常用的场景,而不是试图涵盖所有日期和时间的处理需求。虽然不适用于某些特定场景,但其API足够精简,以方便大多数使用场景。
- 时间与时区的分离:库清晰地分离了物理时间(即
Instant)和依赖于时区的本地时间(即LocalDateTime)。这种设计避免了混用两者可能带来的误用问题。 - 基于ISO 8601标准:所有时间格式都遵循国际标准 ISO 8601,不包括国际化的内容(如不同语言的月份、星期名称等)。
二、库的安装与配置
在使用 kotlinx-datetime 之前,需要在项目中添加依赖。以下是添加依赖的方式:
Gradle
dependencies {implementation("org.jetbrains.kotlinx:kotlinx-datetime:0.6.0")
}
确保在项目的 build.gradle.kts 文件中添加正确的依赖版本。
三、核心类型介绍
kotlinx-datetime 提供了一组核心类型,用于处理日期和时间:
Instant:表示UTC时间刻度中的一个瞬时点。Clock:用于获取当前时刻的时钟接口。LocalDateTime:表示不依赖于时区的日期和时间。LocalDate:表示仅包含日期部分的组件。LocalTime:表示仅包含时间部分的组件。TimeZone:提供时区信息,用于在Instant和LocalDateTime之间进行转换。DateTimePeriod:表示两个瞬时点之间的时间差,包含日期和时间组件。
这些类型的设计使得处理各种日期和时间操作变得更加清晰且直观。
四、使用示例
接下来,我们通过一些常见的场景来展示如何使用这些核心类型和操作。
1. 获取当前时间
获取当前时刻非常简单,使用 Clock.System.now() 可以获得当前的 Instant。
import kotlinx.datetime.*val currentMoment: Instant = Clock.System.now()
println(currentMoment) // 输出当前的UTC时间
2. 转换时间为本地日期时间
Instant 只代表时间刻度,而我们通常需要将其转换为人类可读的本地日期时间。使用 toLocalDateTime 方法并指定时区即可完成转换。
val currentMoment = Clock.System.now()
val datetimeInUtc: LocalDateTime = currentMoment.toLocalDateTime(TimeZone.UTC)
val datetimeInSystemZone: LocalDateTime = currentMoment.toLocalDateTime(TimeZone.currentSystemDefault())println(datetimeInUtc) // 输出UTC的日期时间
println(datetimeInSystemZone) // 输出系统时区的日期时间
3. 获取当前日期和时间
若只关心当前的日期或时间,可以通过 LocalDate 或 LocalTime 获取。
val today: LocalDate = Clock.System.todayIn(TimeZone.currentSystemDefault())
val thisTime: LocalTime = Clock.System.now().toLocalDateTime(TimeZone.currentSystemDefault()).timeprintln(today) // 输出今天的日期
println(thisTime) // 输出当前的时间
4. 日期与时间的构造
我们可以手动构造日期和时间对象。例如,创建一个具体的 LocalDateTime 或 LocalDate:
val specificDateTime = LocalDateTime(2023, 12, 24, 18, 0)
val specificDate = LocalDate(2023, 12, 24)println(specificDateTime) // 2023-12-24T18:00
println(specificDate) // 2023-12-24
5. 日期与时间的加减操作
我们可以轻松地对日期和时间进行加减操作。例如,增加一个时间段到 Instant:
val now: Instant = Clock.System.now()
val futureInstant = now.plus(3, DateTimeUnit.DAY, TimeZone.currentSystemDefault())println(futureInstant) // 当前时间加3天后的时间
6. 时间差计算
kotlinx-datetime 支持计算两个瞬时点之间的时间差。可以通过 periodUntil 方法来获取日期和时间差:
val pastMoment = Instant.parse("2023-01-01T00:00:00Z")
val period = pastMoment.periodUntil(Clock.System.now(), TimeZone.UTC)println(period) // 例如输出 "2 years, 1 month, 20 days"
五、格式化与解析日期
kotlinx-datetime 提供了对 ISO 8601 格式的支持。可以将日期和时间对象格式化为字符串,或从字符串解析日期时间。
// 格式化为字符串
val instantNow = Clock.System.now()
println(instantNow.toString()) // 输出类似于 "2023-10-22T15:30:00Z"// 从字符串解析为 Instant
val parsedInstant = Instant.parse("2023-10-22T15:30:00Z")
println(parsedInstant)
同样地,LocalDateTime、LocalDate 和 LocalTime 也支持类似的操作:
val localDateTime = LocalDateTime.parse("2023-10-22T15:30:00")
val localDate = LocalDate.parse("2023-10-22")
val localTime = LocalTime.parse("15:30:00")println(localDateTime)
println(localDate)
println(localTime)
六、总结
kotlinx-datetime 是一款非常实用的多平台Kotlin库,专注于解决日常开发中常见的日期和时间问题。通过它,开发者可以轻松处理跨时区的时间转换、日期时间的加减操作以及各种格式化和解析任务。希望本文的示例能帮助你更好地理解和使用这个库,提升日期和时间处理的效率。
在实际开发中,选择合适的时间类型和操作至关重要。例如,在处理未来的事件时,应该优先使用 LocalDateTime 而非 Instant,以避免时区规则变化带来的潜在问题。
希望你通过本文对 kotlinx-datetime 有了全面的了解并能灵活运用到你的项目中!
参考资料
- Kotlinx-datetime 官方文档
- Kotlinx-datetime 使用指南
相关文章:
深入了解 kotlinx-datetime:配置与使用指南
深入了解 kotlinx-datetime:配置与使用指南 在Kotlin多平台开发中,处理日期和时间是常见的需求。kotlinx-datetime库提供了强大且简洁的API来帮助开发者应对这一挑战。本文将详细介绍如何配置kotlinx-datetime库,并通过生动的示例演示其核心…...
Qt编程技巧小知识点(6)根据 *IDN? 对程控仪器连接状态进行确认
文章目录 Qt编程技巧小知识点(6)根据 *IDN? 对程控仪器连接状态进行确认小结 Qt编程技巧小知识点(6)根据 *IDN? 对程控仪器连接状态进行确认 确定仪器连接问题,常用的是监测仪器的连接状态,如下代码所示&…...
【Android】Kotlin教程(4)
文章目录 1.field2.计算属性3.主构造函数4.次构造函数5.默认参数6.初始化块7.初始化顺序7.延迟初始化lateinit8.惰性初始化 1.field field 关键字通常与属性的自定义 getter 和 setter 一起使用。当你需要为一个属性提供自定义的行为时,可以使用 field 来访问或设置…...
机票电子行程单如何批量查验?Java机票电子行程单查验接口示例-发票查验接口
机票电子行程单来了,它方便了人们的出行。现如今,随着旅游、差旅市场的回暖与线上业务的蓬勃发展,机票电子行程单的需求量急剧攀升,如何高效且准确地查验这些电子行程单成为许多企业和财务部门关注的焦点。传统的人工查验流程耗时…...
记录element-ui改造select显示为table,并支持多查询条件
最近遇到的一个需求 , 很有趣,是需要一个select组件,要求显示工号,员工姓名,以及区域 三个字段,并且要支持三个字段的查询。显然element原生的组件不适用,这时候我们需要改造一下,把…...
Spearman、Pearson、Euclidean、Cosine、Jaccard,用来衡量不同数据之间的相似性或差异性
1. Spearman相关系数: 用于衡量两个变量之间的排序关系的强度和方向。Spearman相关系数关注的是两个变量的排序一致性,而不关心具体的数值大小。值的范围为-1到1,1表示完全正相关,-1表示完全负相关,0表示无相关性。常…...
Suno 歌曲生成 API 对接说明
随着 AI 的应用变广,各类 AI 程序已逐渐普及。AI 已逐渐深入到人们的工作生活方方面面。而 AI 涉及的行业也越来越多,从最初的写作,到医疗教育,再到现在的音乐。 Suno 是一个专业高质量的 AI 歌曲和音乐创作平台,用户…...
详细且系统的Spring Boot应用开发
为了帮助大家更好地理解如何使用Spring Boot来构建一个基础的Web应用程序,我将通过一个简单的例子来进行说明。这个例子将是一个基本的RESTful API服务,用于管理图书信息。 项目准备 1. 开发环境设置(这个我之前有发文,这里就不详…...
线程支持库(C++11)
线程支持库包含了线程,互斥锁,线程条件变量(class thread),定义于<thread> 线程提供一个并发的实例,需要对应一个“线程函数” 线程的主要任务就是去执行这个"线程函数" 既然线程需要提供一个线程函数,…...
【计网】深入理解NAT机制,内网穿透与内网打洞,代理服务
我没胆量犯错 才把一切错过 --- 林夕 《我对不起我》--- 一文了解NAT机制,代理服务,内网穿透 1 再谈 NAT 机制2 内网穿透与内网打洞3 代理服务器 1 再谈 NAT 机制 NAT机制我们在解决IP地址不足的问题中提到过。为了解决IP地址不足的问题,采…...
C# 创建型设计模式----工厂模式
1 、什么是工厂模式 简单来说就是由一个对象去生成不同的对象,工厂模式是用工厂方法代替new操作的一种模式。工厂方法封装了多个相关联类的new方法,每次实例化这些类的时候不需要new多次,只需要调用工厂类的对应方法即可实例化这些类&#x…...
java中Scanner的nextLine和next方法
思考,输入1 2 3 4 5加上enter,输出什么 import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int[][] m new int[2][2];for (int i 0; i < 2; i) {for (int j 0; j < 2;…...
2024年全国山洪径流模拟与洪水危险性评价技术及典型地区洪水淹没及损失分析
洪水淹没危险性(各种年遇型洪水淹没)是洪水损失评估、风险评估及洪水应急和管理规划等工作的重要基础。当前开展洪水危险性研究工作中的主要困难之一是水文资料稀缺,尤其是径流资料稀缺,既包括径流观测资料在时间上的短缺…...
CDC 同步数据需要的MySQL数据权限
授权命令如下: grant Replication client on *.* to username%; grant Replication slave on *.* to username%; flush privileges;...
Ubuntu20.04 更新Nvidia驱动 + 安装CUDA12.1 + cudnn8.9.7
一、概述 最近客户给了几台GPU服务器,长期放置落灰那种,然后想利用起来,所以上去看看了配置,系统是Ubuntu20.04,相关的驱动版本稍嫌老一些,所以需要更新Nvidia驱动,同时在安装CUDA和CUDNN,查看了显卡型号之后,打算使用onnxruntime进行推理,对比了版本,最后选择了CUD…...
算法自学 Lesson3 - 逻辑回归(LR)
目录 背景 一、适用数据集 1. 数据集选择 1.1 领域 1.2 数据集维度 1.3 记录行(样本数量) 2. 本文数据集介绍 3. 数据集下载 注意 二、逻辑回归的基本原理 1. 目的 2. Sigmoid 函数 3. 类别划分 4. 召回率 三、代码 1. 导入所需包&数…...
文件IO流
1.文件流概念 2.文件创建方式 3.常用方法 4.IO流原理 (1)InputStream,OutputStream, Reader, Writer四个都是抽象类,无法直接new, 需要由子类继承,然后new子类; (2)Reader和Writer…...
拥塞控制与TCP子问题(粘包问题,异常情况等)
拥塞控制 除了拥塞控制 以上的策越都是为了解决tcp 客户端和服务端提高效率,解决丢包的策略 但是拥塞控制是了为解决网络拥堵 出现了大面积丢包,我们发送方会判定是网络出现了问题? 丢包好解决,我们直接采用超时重传&#…...
stm32入门教程--DMA 超详细!!!
目录 简介 工作模式 1、数据转运DMA 2、ADC扫描模式DMA 简介 工作模式 1、数据转运DMA 这个例子的任务是将SRAM的数组DataA,转运到另一个数组DataB中,这个基本结构里的各个参数应该如何配置呢? 首先是外设站点和存储器站点的起始地址、…...
【使用Flask构建RESTful API】从零开始开发简单的Web服务!
使用Flask构建RESTful API:从零开始开发简单的Web服务 引言 随着Web应用程序的广泛使用,RESTful API已成为现代Web服务的核心技术之一。通过RESTful API,我们可以轻松地创建、读取、更新和删除(CRUD)数据,…...
装饰模式(Decorator Pattern)重构java邮件发奖系统实战
前言 现在我们有个如下的需求,设计一个邮件发奖的小系统, 需求 1.数据验证 → 2. 敏感信息加密 → 3. 日志记录 → 4. 实际发送邮件 装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其…...
从WWDC看苹果产品发展的规律
WWDC 是苹果公司一年一度面向全球开发者的盛会,其主题演讲展现了苹果在产品设计、技术路线、用户体验和生态系统构建上的核心理念与演进脉络。我们借助 ChatGPT Deep Research 工具,对过去十年 WWDC 主题演讲内容进行了系统化分析,形成了这份…...
从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路
进入2025年以来,尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断,但全球市场热度依然高涨,入局者持续增加。 以国内市场为例,天眼查专业版数据显示,截至5月底,我国现存在业、存续状态的机器人相关企…...
Java多线程实现之Callable接口深度解析
Java多线程实现之Callable接口深度解析 一、Callable接口概述1.1 接口定义1.2 与Runnable接口的对比1.3 Future接口与FutureTask类 二、Callable接口的基本使用方法2.1 传统方式实现Callable接口2.2 使用Lambda表达式简化Callable实现2.3 使用FutureTask类执行Callable任务 三、…...
跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...
浅谈不同二分算法的查找情况
二分算法原理比较简单,但是实际的算法模板却有很多,这一切都源于二分查找问题中的复杂情况和二分算法的边界处理,以下是博主对一些二分算法查找的情况分析。 需要说明的是,以下二分算法都是基于有序序列为升序有序的情况…...
vue3+vite项目中使用.env文件环境变量方法
vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量,这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...
Element Plus 表单(el-form)中关于正整数输入的校验规则
目录 1 单个正整数输入1.1 模板1.2 校验规则 2 两个正整数输入(联动)2.1 模板2.2 校验规则2.3 CSS 1 单个正整数输入 1.1 模板 <el-formref"formRef":model"formData":rules"formRules"label-width"150px"…...
GC1808高性能24位立体声音频ADC芯片解析
1. 芯片概述 GC1808是一款24位立体声音频模数转换器(ADC),支持8kHz~96kHz采样率,集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器,适用于高保真音频采集场景。 2. 核心特性 高精度:24位分辨率,…...
Angular微前端架构:Module Federation + ngx-build-plus (Webpack)
以下是一个完整的 Angular 微前端示例,其中使用的是 Module Federation 和 npx-build-plus 实现了主应用(Shell)与子应用(Remote)的集成。 🛠️ 项目结构 angular-mf/ ├── shell-app/ # 主应用&…...
