sort
所在位置是kotlin.collections.sort
,其相關用法介紹如下。
用法一
就地對數組進行排序。
例子:
import kotlin.test.*
fun main(args: Array<String>) {
//sampleStart
val intArray = intArrayOf(4, 3, 2, 1)
// before sorting
println(intArray.joinToString()) // 4, 3, 2, 1
intArray.sort()
// after sorting
println(intArray.joinToString()) // 1, 2, 3, 4
//sampleEnd
}
輸出:
4, 3, 2, 1 1, 2, 3, 4
用法二
根據元素的自然順序對數組進行就地排序。
排序是 stable
。這意味著相等的元素在排序後保持彼此相對的順序。
例子:
import kotlin.test.*
fun main(args: Array<String>) {
//sampleStart
class Person(val firstName: String, val lastName: String) : Comparable<Person> {
override fun compareTo(other: Person): Int = this.lastName.compareTo(other.lastName)
override fun toString(): String = "$firstName $lastName"
}
val people = arrayOf(
Person("Ragnar", "Lodbrok"),
Person("Bjorn", "Ironside"),
Person("Sweyn", "Forkbeard")
)
// before sorting
println(people.joinToString()) // Ragnar Lodbrok, Bjorn Ironside, Sweyn Forkbeard
people.sort()
// after sorting
println(people.joinToString()) // Sweyn Forkbeard, Bjorn Ironside, Ragnar Lodbrok
//sampleEnd
}
輸出:
Ragnar Lodbrok, Bjorn Ironside, Sweyn Forkbeard Sweyn Forkbeard, Bjorn Ironside, Ragnar Lodbrok
用法三
就地對數組中的範圍進行排序。
排序是 stable
。這意味著相等的元素在排序後保持彼此相對的順序。
例子:
import kotlin.test.*
fun main(args: Array<String>) {
//sampleStart
class Person(val firstName: String, val lastName: String) : Comparable<Person> {
override fun compareTo(other: Person): Int = this.lastName.compareTo(other.lastName)
override fun toString(): String = "$firstName $lastName"
}
val people = arrayOf(
Person("Ragnar", "Lodbrok"),
Person("Bjorn", "Ironside"),
Person("Sweyn", "Forkbeard")
)
// before sorting
println(people.joinToString()) // Ragnar Lodbrok, Bjorn Ironside, Sweyn Forkbeard
people.sort(0, 2)
// after sorting
println(people.joinToString()) // Bjorn Ironside, Ragnar Lodbrok, Sweyn Forkbeard
//sampleEnd
}
輸出:
Ragnar Lodbrok, Bjorn Ironside, Sweyn Forkbeard Bjorn Ironside, Ragnar Lodbrok, Sweyn Forkbeard
參數
fromIndex
- 要排序的範圍(包括)的開始,默認為 0。
toIndex
- 要排序的範圍的末尾(不包括),默認情況下此數組的大小。
異常
用法四
就地對數組中的範圍進行排序。
例子:
import kotlin.test.*
fun main(args: Array<String>) {
//sampleStart
val intArray = intArrayOf(4, 3, 2, 1)
// before sorting
println(intArray.joinToString()) // 4, 3, 2, 1
intArray.sort(0, 3)
// after sorting
println(intArray.joinToString()) // 2, 3, 4, 1
//sampleEnd
}
輸出:
4, 3, 2, 1 2, 3, 4, 1
參數
fromIndex
- 要排序的範圍(包括)的開始,默認為 0。
toIndex
- 要排序的範圍的末尾(不包括),默認情況下此數組的大小。
異常
用法五
就地對數組進行排序。
例子:
import kotlin.test.*
fun main(args: Array<String>) {
//sampleStart
val intArray = intArrayOf(4, 3, 2, 1)
// before sorting
println(intArray.joinToString()) // 4, 3, 2, 1
intArray.sort()
// after sorting
println(intArray.joinToString()) // 1, 2, 3, 4
//sampleEnd
}
輸出:
4, 3, 2, 1 1, 2, 3, 4
用法六
就地對數組中的範圍進行排序。
例子:
import kotlin.test.*
fun main(args: Array<String>) {
//sampleStart
val intArray = intArrayOf(4, 3, 2, 1)
// before sorting
println(intArray.joinToString()) // 4, 3, 2, 1
intArray.sort(0, 3)
// after sorting
println(intArray.joinToString()) // 2, 3, 4, 1
//sampleEnd
}
輸出:
4, 3, 2, 1 2, 3, 4, 1
參數
fromIndex
- 要排序的範圍(包括)的開始,默認為 0。
toIndex
- 要排序的範圍的末尾(不包括),默認情況下此數組的大小。
異常
用法七
根據自然排序順序對列表中的元素進行就地排序。
排序是 stable
。這意味著相等的元素在排序後保持彼此相對的順序。
例子:
import kotlin.test.*
fun main(args: Array<String>) {
//sampleStart
val mutableList = mutableListOf(4, 3, 2, 1)
// before sorting
println(mutableList.joinToString()) // 4, 3, 2, 1
mutableList.sort()
// after sorting
println(mutableList.joinToString()) // 1, 2, 3, 4
//sampleEnd
}
輸出:
4, 3, 2, 1 1, 2, 3, 4
用法八
用法九
@DeprecatedSinceKotlin("1.6") fun <T> Array<out T>.sort(
comparison: (a: T, b: T) -> Int)
已棄用:改用 sortWith根據給定的 comparison 函數指定的順序對數組進行就地排序。
排序是 stable
。這意味著相等的元素在排序後保持彼此相對的順序。
用法十
@DeprecatedSinceKotlin("1.6") inline fun ByteArray.sort(
noinline comparison: (a: Byte, b: Byte) -> Int)
已棄用:使用標準庫中的其他排序函數@DeprecatedSinceKotlin("1.6") inline fun ShortArray.sort(
noinline comparison: (a: Short, b: Short) -> Int)
已棄用:使用標準庫中的其他排序函數@DeprecatedSinceKotlin("1.6") inline fun IntArray.sort(
noinline comparison: (a: Int, b: Int) -> Int)
已棄用:使用標準庫中的其他排序函數@DeprecatedSinceKotlin("1.6") inline fun LongArray.sort(
noinline comparison: (a: Long, b: Long) -> Int)
已棄用:使用標準庫中的其他排序函數@DeprecatedSinceKotlin("1.6") inline fun FloatArray.sort(
noinline comparison: (a: Float, b: Float) -> Int)
已棄用:使用標準庫中的其他排序函數@DeprecatedSinceKotlin("1.6") inline fun DoubleArray.sort(
noinline comparison: (a: Double, b: Double) -> Int)
已棄用:使用標準庫中的其他排序函數@DeprecatedSinceKotlin("1.6") inline fun CharArray.sort(
noinline comparison: (a: Char, b: Char) -> Int)
已棄用:使用標準庫中的其他排序函數根據給定的 comparison 函數指定的順序對數組進行就地排序。
相關用法
- Kotlin sortedBy用法及代碼示例
- Kotlin sortWith用法及代碼示例
- Kotlin scan用法及代碼示例
- Kotlin splitToSequence用法及代碼示例
- Kotlin scanIndexed用法及代碼示例
- Kotlin setValue用法及代碼示例
- Kotlin associateBy用法及代碼示例
- Kotlin all用法及代碼示例
- Kotlin map用法及代碼示例
- Kotlin filterNot用法及代碼示例
- Kotlin reduceRight用法及代碼示例
- Kotlin Random.Default用法及代碼示例
- Kotlin Byte.inc用法及代碼示例
- Kotlin getValue用法及代碼示例
- Kotlin Double.dec用法及代碼示例
- Kotlin windowedSequence用法及代碼示例
- Kotlin contentToString用法及代碼示例
- Kotlin groupByTo用法及代碼示例
- Kotlin commonPrefixWith用法及代碼示例
- Kotlin MatchResult.Destructured用法及代碼示例
- Kotlin Delegates.notNull用法及代碼示例
- Kotlin ifBlank用法及代碼示例
- Kotlin filterNotTo用法及代碼示例
- Kotlin getOrPut用法及代碼示例
- Kotlin Triple.<init>用法及代碼示例
注:本文由純淨天空篩選整理自kotlinlang.org大神的英文原創作品 kotlin.collections.sort。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。