Якщо ви використовуєте Kotlin, ви можете використовувати функції розширення як такі, наприклад:
fun <T> LongSparseArray<T>.valuesIterator(): Iterator<T> {
val nSize = this.size()
return object : Iterator<T> {
var i = 0
override fun hasNext(): Boolean = i < nSize
override fun next(): T = valueAt(i++)
}
}
fun <T> LongSparseArray<T>.keysIterator(): Iterator<Long> {
val nSize = this.size()
return object : Iterator<Long> {
var i = 0
override fun hasNext(): Boolean = i < nSize
override fun next(): Long = keyAt(i++)
}
}
fun <T> LongSparseArray<T>.entriesIterator(): Iterator<Pair<Long, T>> {
val nSize = this.size()
return object : Iterator<Pair<Long, T>> {
var i = 0
override fun hasNext(): Boolean = i < nSize
override fun next() = Pair(keyAt(i), valueAt(i++))
}
}
Ви також можете конвертувати в список, якщо бажаєте. Приклад:
sparseArray.keysIterator().asSequence().toList()
Я думаю, що можливо навіть безпечно видаляти елементи, використовуючи remove
на LongSparseArray
собі (а не на ітераторі), як це відбувається у порядку зростання.
EDIT: Здається, існує навіть простіший спосіб, використовуючи collection-ktx (приклад тут ). Він реалізований дуже схожим чином на те, що я написав, актально.
Gradle вимагає цього:
implementation 'androidx.core:core-ktx:#'
implementation 'androidx.collection:collection-ktx:#'
Ось використання для LongSparseArray:
val sparse= LongSparseArray<String>()
for (key in sparse.keyIterator()) {
}
for (value in sparse.valueIterator()) {
}
sparse.forEach { key, value ->
}
А для тих, хто використовує Java, ви можете використовувати LongSparseArrayKt.keyIterator
, LongSparseArrayKt.valueIterator
і LongSparseArrayKt.forEach
, наприклад. Те ж саме для інших випадків.