Comparable

Platform and version requirements: JVM (1.0), JS (1.1), Native (1.3)
interface Comparable<in T>

Classes which inherit from this interface have a defined total ordering between their instances.

Functions

Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

compareTo

Compares this object with the specified object for order. Returns zero if this object is equal to the specified other object, a negative number if it's less than other, or a positive number if it's greater than other.

abstract operator fun compareTo(other: T): Int

Extension Functions

Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

coerceAtLeast

Ensures that this value is not less than the specified minimumValue.

fun <T : Comparable<T>> T.coerceAtLeast(minimumValue: T): T
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

coerceAtMost

Ensures that this value is not greater than the specified maximumValue.

fun <T : Comparable<T>> T.coerceAtMost(maximumValue: T): T
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

coerceIn

Ensures that this value lies in the specified range minimumValue..maximumValue.

fun <T : Comparable<T>> T.coerceIn(
    minimumValue: T?, 
    maximumValue: T?
): T

Ensures that this value lies in the specified range.

fun <T : Comparable<T>> T.coerceIn(
    range: ClosedFloatingPointRange<T>
): T
fun <T : Comparable<T>> T.coerceIn(range: ClosedRange<T>): T
Platform and version requirements: JVM (1.6), JS (1.6), Native (1.6)

compareTo

Compares this object with the specified object for order. Returns zero if this object is equal to the specified other object, a negative number if it's less than other, or a positive number if it's greater than other.

infix fun <T> Comparable<T>.compareTo(other: T): Int
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

rangeTo

Creates a range from this Comparable value to the specified that value.

operator fun <T : Comparable<T>> T.rangeTo(
    that: T
): ClosedRange<T>

Inheritors

Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

Boolean

Represents a value which is either true or false. On the JVM, non-nullable values of this type are represented as values of the primitive type boolean.

class Boolean : Comparable<Boolean>
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

Byte

Represents a 8-bit signed integer. On the JVM, non-nullable values of this type are represented as values of the primitive type byte.

class Byte : Number, Comparable<Byte>
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

Char

Represents a 16-bit Unicode character.

class Char : Comparable<Char>
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

Double

Represents a double-precision 64-bit IEEE 754 floating point number. On the JVM, non-nullable values of this type are represented as values of the primitive type double.

class Double : Number, Comparable<Double>
Platform and version requirements: JVM (1.6), JS (1.6), Native (1.6)

Duration

Represents the amount of time one instant of time is away from another instant.

class Duration : Comparable<Duration>
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

Enum

The common base class of all enum classes. See the Kotlin language documentation for more information on enum classes.

abstract class Enum<E : Enum<E>> : Comparable<E>
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

Float

Represents a single-precision 32-bit IEEE 754 floating point number. On the JVM, non-nullable values of this type are represented as values of the primitive type float.

class Float : Number, Comparable<Float>
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

Int

Represents a 32-bit signed integer. On the JVM, non-nullable values of this type are represented as values of the primitive type int.

class Int : Number, Comparable<Int>
Platform and version requirements: JVM (1.1), JS (1.1), Native (1.1)

KotlinVersion

Represents a version of the Kotlin standard library.

class KotlinVersion : Comparable<KotlinVersion>
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

Long

Represents a 64-bit signed integer. On the JVM, non-nullable values of this type are represented as values of the primitive type long.

class Long : Number, Comparable<Long>
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

Short

Represents a 16-bit signed integer. On the JVM, non-nullable values of this type are represented as values of the primitive type short.

class Short : Number, Comparable<Short>
Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)

String

The String class represents character strings. All string literals in Kotlin programs, such as "abc", are implemented as instances of this class.

class String : Comparable<String>, CharSequence
Platform and version requirements: JVM (1.5), JS (1.5), Native (1.5)

UByte

class UByte : Comparable<UByte>
Platform and version requirements: JVM (1.5), JS (1.5), Native (1.5)

UInt

class UInt : Comparable<UInt>
Platform and version requirements: JVM (1.5), JS (1.5), Native (1.5)

ULong

class ULong : Comparable<ULong>
Platform and version requirements: JVM (1.5), JS (1.5), Native (1.5)

UShort

class UShort : Comparable<UShort>

© 2010–2021 JetBrains s.r.o. and Kotlin Programming Language contributors
Licensed under the Apache License, Version 2.0.
https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/-comparable/index.html