commonMain.kotlin.time.measureTime.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kotlin-stdlib Show documentation
Show all versions of kotlin-stdlib Show documentation
Kotlin Standard Library for JVM
/*
* Copyright 2010-2024 JetBrains s.r.o. and Kotlin Programming Language contributors.
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
*/
package kotlin.time
import kotlin.contracts.*
/**
* Executes the given function [block] and returns the duration of the elapsed time interval.
*
* The elapsed time is measured with [TimeSource.Monotonic] which is the most precise
* available time source on the platform.
*
* @sample samples.time.MeasureTime.measureTimeSample
*/
@SinceKotlin("1.9")
@WasExperimental(ExperimentalTime::class)
public inline fun measureTime(block: () -> Unit): Duration {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
return TimeSource.Monotonic.measureTime(block)
}
/**
* Executes the given function [block] and returns the duration of the elapsed time interval.
*
* The elapsed time is measured with the specified `this` [TimeSource] instance.
*
* @sample samples.time.MeasureTime.explicitMeasureTimeSample
*/
@SinceKotlin("1.9")
@WasExperimental(ExperimentalTime::class)
public inline fun TimeSource.measureTime(block: () -> Unit): Duration {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
val mark = markNow()
block()
return mark.elapsedNow()
}
/**
* Executes the given function [block] and returns the duration of the elapsed time interval.
*
* The elapsed time is measured with the specified `this` [TimeSource.Monotonic] instance.
* The explicit instance allows using non-boxed version of [TimeSource.Monotonic.ValueTimeMark]
* and, optionally, be more explicit about the intent.
*
* @sample samples.time.MeasureTime.monotonicMeasureTimeSample
*/
@SinceKotlin("1.9")
@WasExperimental(ExperimentalTime::class)
public inline fun TimeSource.Monotonic.measureTime(block: () -> Unit): Duration {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
val mark = markNow()
block()
return mark.elapsedNow()
}
/**
* Data class representing a result of executing an action, along with the duration of the elapsed time interval.
*
* @property value the result of the action.
* @property duration the time elapsed to execute the action.
*/
@SinceKotlin("1.9")
@WasExperimental(ExperimentalTime::class)
public data class TimedValue(val value: T, val duration: Duration)
/**
* Executes the given function [block] and returns an instance of [TimedValue] class, containing both
* the result of the function execution and the duration of the elapsed time interval.
*
* The elapsed time is measured with [TimeSource.Monotonic] which is the most precise
* available time source on the platform.
*
* @sample samples.time.MeasureTime.measureTimedValueSample
*/
@SinceKotlin("1.9")
@WasExperimental(ExperimentalTime::class)
public inline fun measureTimedValue(block: () -> T): TimedValue {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
return TimeSource.Monotonic.measureTimedValue(block)
}
/**
* Executes the given function [block] and returns an instance of [TimedValue] class, containing both
* the result of function execution and the duration of the elapsed time interval.
*
* The elapsed time is measured with the specified `this` [TimeSource] instance.
*
* @sample samples.time.MeasureTime.explicitMeasureTimedValueSample
*/
@SinceKotlin("1.9")
@WasExperimental(ExperimentalTime::class)
public inline fun TimeSource.measureTimedValue(block: () -> T): TimedValue {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
val mark = markNow()
val result = block()
return TimedValue(result, mark.elapsedNow())
}
/**
* Executes the given function [block] and returns an instance of [TimedValue] class, containing both
* the result of function execution and the duration of the elapsed time interval.
*
* The elapsed time is measured with the specified `this` [TimeSource.Monotonic] instance.
* The explicit instance allows using non-boxed version of [TimeSource.Monotonic.ValueTimeMark]
* and, optionally, be more explicit about the intent.
*
* @sample samples.time.MeasureTime.monotonicMeasureTimedValueSample
*/
@SinceKotlin("1.9")
@WasExperimental(ExperimentalTime::class)
public inline fun TimeSource.Monotonic.measureTimedValue(block: () -> T): TimedValue {
contract {
callsInPlace(block, InvocationKind.EXACTLY_ONCE)
}
val mark = markNow()
val result = block()
return TimedValue(result, mark.elapsedNow())
}