6.Kotlin的Duration类

以下是 Kotlin 中 Duration 类的所有方法(基于 Kotlin 1.9+ 标准库),包含方法签名、返回值、说明及示例:

一、属性(Properties)

方法签名 返回值 说明 示例
val inDays: Long Long 以天为单位的时长(向下取整) Duration.ofHours(25).inDays → 1
val inHours: Long Long 以小时为单位的时长(向下取整) Duration.ofMinutes(130).inHours → 2
val inMinutes: Long Long 以分钟为单位的时长(向下取整) Duration.ofSeconds(370).inMinutes → 6
val inSeconds: Long Long 以秒为单位的时长(向下取整) Duration.ofMillis(2500).inSeconds → 2
val inMillis: Long Long 以毫秒为单位的总时长 Duration.ofSeconds(1).inMillis → 1000
val isZero: Boolean Boolean 判断时长是否为 0 Duration.ZERO.isZero → true
val isPositive: Boolean Boolean 判断时长是否为正数(>0) Duration.ofNanos(1).isPositive → true
val isNegative: Boolean Boolean 判断时长是否为负数(<0) Duration.ofNanos(-1).isNegative → true

二、运算方法(Operations)

方法签名 返回值 说明 示例
operator fun plus(other: Duration): Duration Duration 加另一个时长 Duration.ofHours(2) + Duration.ofMinutes(30) → 2h30m
operator fun minus(other: Duration): Duration Duration 减另一个时长 Duration.ofHours(3) - Duration.ofMinutes(45) → 2h15m
fun multipliedBy(scalar: Long): Duration Duration 乘以倍数 Duration.ofMinutes(10).multipliedBy(2) → 20m
fun dividedBy(divisor: Long): Duration Duration 除以除数(向下取整) Duration.ofSeconds(60).dividedBy(3) → 20s
fun dividedBy(other: Duration): Long Long 除以另一个时长(得到倍数,向下取整) Duration.ofHours(4).dividedBy(Duration.ofHours(2)) → 2
fun negated(): Duration Duration 返回相反符号的时长 Duration.ofHours(1).negated() → -1h
fun abs(): Duration Duration 返回时长的绝对值 Duration.ofHours(-2).abs() → 2h

三、比较方法(Comparisons)

方法签名 返回值 说明 示例
operator fun compareTo(other: Duration): Int Int 比较两个时长:负(<)、0(=)、正(>) Duration.ofMinutes(30).compareTo(Duration.ofHours(1)) → -1
operator fun rangeTo(other: Duration): ClosedRange<Duration> ClosedRange<Duration> 创建时长范围 val range = Duration.ofHours(1)..Duration.ofHours(2)

四、静态创建方法(Static Factories)

方法签名 返回值 说明 示例
fun ofNanos(nanos: Long): Duration Duration 从纳秒创建时长 Duration.ofNanos(1_000_000) → 1ms
fun ofMillis(millis: Long): Duration Duration 从毫秒创建时长 Duration.ofMillis(1000) → 1s
fun ofSeconds(seconds: Long): Duration Duration 从秒创建时长 Duration.ofSeconds(60) → 1m
fun ofSeconds(seconds: Long, nanoAdjustment: Long): Duration Duration 从秒+纳秒偏移创建 Duration.ofSeconds(1, 500_000_000) → 1.5s
fun ofMinutes(minutes: Long): Duration Duration 从分钟创建时长 Duration.ofMinutes(60) → 1h
fun ofHours(hours: Long): Duration Duration 从小时创建时长 Duration.ofHours(24) → 1d
fun ofDays(days: Long): Duration Duration 从天数创建时长 Duration.ofDays(1) → 24h
fun between(startInclusive: Instant, endExclusive: Instant): Duration Duration 计算两个Instant的差 Duration.between(Instant.parse("2023-01-01T00:00:00Z"), Instant.parse("2023-01-01T01:00:00Z")) → 1h
fun between(startInclusive: LocalTime, endExclusive: LocalTime): Duration Duration 计算两个LocalTime的差 Duration.between(LocalTime.of(9,0), LocalTime.of(10,0)) → 1h
fun parse(text: CharSequence): Duration Duration 从字符串解析时长(如PT1H30M Duration.parse("PT1H30M") → 1h30m

五、其他方法(Other)

方法签名 返回值 说明 示例
override fun toString(): String String 返回标准化字符串(ISO-8601格式) Duration.ofMinutes(90).toString() → "PT1H30M"

说明:

  1. 所有方法均来自 kotlin.time.Duration(Kotlin 标准库)及 Java 互操作的 java.time.Duration 扩展。
  2. 示例中 表示返回结果的简化描述(非实际返回值的字符串形式)。
  3. 负数时长的转换(如 inDays)会向下取整(例如 -1.5hinHours-2)。

通过这些方法,Duration 可以完整支持时长的创建、转换、运算和比较,适用于所有需要处理时间间隔的场景。

相关推荐
程序视点1 分钟前
Escrcpy 3.0投屏控制软件使用教程:无线/有线连接+虚拟显示功能等
android
yueyuebaobaoxinx1 小时前
MATLAB 与 Simulink 联合仿真:控制系统建模与动态性能优化
开发语言·matlab·性能优化
superlls2 小时前
(计算机网络)JWT三部分及 Signature 作用
java·开发语言·计算机网络
东京老树根3 小时前
Android - 用Scrcpy 将手机投屏到Windows电脑上
android
一只鲲3 小时前
56 C++ 现代C++编程艺术5-万能引用
开发语言·c++
liulilittle4 小时前
.NET反射与IL反编译核心技术
开发语言·数据库·c#·.net·反射·反编译·il
Wgllss4 小时前
完整烟花效果,Compose + 协程 + Flow + Channel 轻松实现
android·架构·android jetpack
独自破碎E4 小时前
得物25年春招-安卓部分笔试题1
android
雨白5 小时前
Android 自定义 View:精通文字的测量与高级排版
android