reduceRightIndexed所在位置是kotlin.collections.reduceRightIndexed,其相關用法介紹如下。

用法一

inline fun <S, T : S> Array<out T>.reduceRightIndexed(
    operation: (index: Int, T, acc: S) -> S
): S
inline fun ByteArray.reduceRightIndexed(
    operation: (index: Int, Byte, acc: Byte) -> Byte
): Byte
inline fun ShortArray.reduceRightIndexed(
    operation: (index: Int, Short, acc: Short) -> Short
): Short
inline fun IntArray.reduceRightIndexed(
    operation: (index: Int, Int, acc: Int) -> Int
): Int
inline fun LongArray.reduceRightIndexed(
    operation: (index: Int, Long, acc: Long) -> Long
): Long
inline fun FloatArray.reduceRightIndexed(
    operation: (index: Int, Float, acc: Float) -> Float
): Float
inline fun DoubleArray.reduceRightIndexed(
    operation: (index: Int, Double, acc: Double) -> Double
): Double
inline fun BooleanArray.reduceRightIndexed(
    operation: (index: Int, Boolean, acc: Boolean) -> Boolean
): Boolean
inline fun CharArray.reduceRightIndexed(
    operation: (index: Int, Char, acc: Char) -> Char
): Char
@ExperimentalUnsignedTypes inline fun UIntArray.reduceRightIndexed(
    operation: (index: Int, UInt, acc: UInt) -> UInt
): UInt
@ExperimentalUnsignedTypes inline fun ULongArray.reduceRightIndexed(
    operation: (index: Int, ULong, acc: ULong) -> ULong
): ULong
@ExperimentalUnsignedTypes inline fun UByteArray.reduceRightIndexed(
    operation: (index: Int, UByte, acc: UByte) -> UByte
): UByte
@ExperimentalUnsignedTypes inline fun UShortArray.reduceRightIndexed(
    operation: (index: Int, UShort, acc: UShort) -> UShort
): UShort

從最後一個元素開始累加值,並從右到左將 operation 應用於每個元素及其在原始數組中的索引和當前累加器值。

如果此數組為空,則引發異常。如果數組可以按預期方式為空,請改用reduceRightIndexedOrNull。當接收器為空時,它返回null

例子:

import kotlin.test.*

fun main(args: Array<String>) {
//sampleStart
val strings = listOf("a", "b", "c", "d")
println(strings.reduceRight { string, acc -> acc + string }) // dcba
println(strings.reduceRightIndexed { index, string, acc -> acc + string + index }) // dc2b1a0

// emptyList<Int>().reduceRight { _, _ -> 0 } //  will fail
//sampleEnd
}

輸出:

dcba
dc2b1a0

參數

operation- 獲取元素索引、元素本身和當前累加器值的函數,並計算下一個累加器值。

用法二

inline fun <S, T : S> List<T>.reduceRightIndexed(
    operation: (index: Int, T, acc: S) -> S
): S

從最後一個元素開始累加值,並從右到左將 operation 應用於每個元素,其在原始列表中的索引和當前累加器值。

如果此列表為空,則引發異常。如果列表可以按預期方式為空,請改用reduceRightIndexedOrNull。當接收器為空時,它返回null

例子:

import kotlin.test.*

fun main(args: Array<String>) {
//sampleStart
val strings = listOf("a", "b", "c", "d")
println(strings.reduceRight { string, acc -> acc + string }) // dcba
println(strings.reduceRightIndexed { index, string, acc -> acc + string + index }) // dc2b1a0

// emptyList<Int>().reduceRight { _, _ -> 0 } //  will fail
//sampleEnd
}

輸出:

dcba
dc2b1a0

參數

operation- 獲取元素索引、元素本身和當前累加器值的函數,並計算下一個累加器值。