W3cubDocs

/Kotlin

filter

Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)
inline fun <T> Array<out T>.filter(
    predicate: (T) -> Boolean
): List<T>
inline fun ByteArray.filter(
    predicate: (Byte) -> Boolean
): List<Byte>
inline fun ShortArray.filter(
    predicate: (Short) -> Boolean
): List<Short>
inline fun IntArray.filter(
    predicate: (Int) -> Boolean
): List<Int>
inline fun LongArray.filter(
    predicate: (Long) -> Boolean
): List<Long>
inline fun FloatArray.filter(
    predicate: (Float) -> Boolean
): List<Float>
inline fun DoubleArray.filter(
    predicate: (Double) -> Boolean
): List<Double>
inline fun BooleanArray.filter(
    predicate: (Boolean) -> Boolean
): List<Boolean>
inline fun CharArray.filter(
    predicate: (Char) -> Boolean
): List<Char>
inline fun <T> Iterable<T>.filter(
    predicate: (T) -> Boolean
): List<T>
@ExperimentalUnsignedTypes inline fun UIntArray.filter(
    predicate: (UInt) -> Boolean
): List<UInt>
@ExperimentalUnsignedTypes inline fun ULongArray.filter(
    predicate: (ULong) -> Boolean
): List<ULong>
@ExperimentalUnsignedTypes inline fun UByteArray.filter(
    predicate: (UByte) -> Boolean
): List<UByte>
@ExperimentalUnsignedTypes inline fun UShortArray.filter(
    predicate: (UShort) -> Boolean
): List<UShort>

Returns a list containing only elements matching the given predicate.

Platform and version requirements: JVM (1.0), JS (1.0), Native (1.0)
inline fun <K, V> Map<out K, V>.filter(
    predicate: (Entry<K, V>) -> Boolean
): Map<K, V>

Returns a new map containing all key-value pairs matching the given predicate.

The returned map preserves the entry iteration order of the original map.

import kotlin.test.*
import java.util.*

fun main(args: Array<String>) {
//sampleStart
val originalMap = mapOf("key1" to 1, "key2" to 2, "key3" to 3)

val filteredMap = originalMap.filter { it.value < 2 }

println(filteredMap) // {key1=1}
// original map has not changed
println(originalMap) // {key1=1, key2=2, key3=3}

val nonMatchingPredicate: ((Map.Entry<String, Int>)) -> Boolean = { it.value == 0 }
val emptyMap = originalMap.filter(nonMatchingPredicate)
println(emptyMap) // {}
//sampleEnd
}

© 2010–2019 JetBrains s.r.o.
Licensed under the Apache License, Version 2.0.
https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/filter.html