本文是研讨官方
core-ktx库的第三篇文章
,旨在探求该库中有哪些东西类或办法能够进步咱们的开发功率。
前两篇文章的参考链接如下:
你需求了解的官方core-ktx库kotlin为什么流行不起来能对开发带来哪些便当1
官方core-ktx库能对富文本Span开发带来哪些便当?
本篇文章主要是研讨
core-ktx
库对SparseArray
系列和Pair
开发能代码哪些便当!!
SparseArray
系列
SparseArray
、LongSparseArray
系列便数据结构与算法是一种支撑key-value
数据结构形式读写的变量名封装类,相比较于HashMap
的有变量值点有两个:
- 键值
key
是一个根本数据类型,而不是一个根本数据类型对应的封装类,不需求装箱
- 它的数据结构是键值
key
一个数组,value
值一个数组,不像HashMap
,基于Entry
对key-value
进行封装再进行读写
PS:Android中还存在另一系列调集
SparseIntArray
、SparseBooleanArray
、SparseLongArray
,这些调集更厉害,key和value都是根本数据类型
,不需求装变量泵箱,不要和上面的调集搞混了。不过这两种调集core-ktx
供给的扩展封变量泵装都几乎相同,就效率计算公式不独自进数据结构行一一阐述了。
-
SparseArray<T>.size()
获取调集大小这个没什么别致,便是对
SparseArray
原来获取大小的方式size()
进行了一层封装,借助于kot数据结构c语言版第二版课后答案lin的语法糖,能够当成特点
的形式调用(本Android质上还是调用的办法
):private fun test5() { val sparseArray: SparseArray<String> = SparseArray<String>() val size = sparseArray.size }
-
SparseArray<T>.contains(key: Int)
判别包含指定key
能够看到这个办法运用了
operator
润饰,是一变量与函数个运算符重载办法,重载了运算符in
,运用如下:@RequiresApi(Build.VERSION_CODES.R) private fun test5() { val sparseArray: SparseArray<String> = SparseArray<String>() val isContain = 5 in sparseArray }
不过这个api要求
SDK>=30
才能运用,咱们能够直接将源码copy到项目东西类库中运用即可。 -
SparseArray<android平板电脑价格T>.plus(other: SparseArray<T>kotlin和java)
并合kotlin语言并两个调集为一个新调集这也是一个运算符重载函数,重载了运算符
+
,项目中能够这样运用:private fun test5() { val sparseArray1: SparseArray<String> = SparseArray<String>() val sparseArray2: SparseArray<String> = SparseArray<String>() val newArray = sparseArray1 + sparseArray2 }
-
SparseArray<T>.containsValue(value: T)
判别是否存在指定value
这个和上面的
contains
办法相似,不过这个是判别某个value值是否在该调集中,相同也是重载了运算符in
-
SparseArray<T>.set效率是什么意思(key: Int, value: T)
写入数据重载了运算符
[]
的函数,能够这样向调集中写入数据:private fun test5() { val sparseArray1: SparseArray<String> = SparseArray<String>() sparseArray1[10] = "" }
-
SparseArray&l数据结构实验报告t;T>.变量值getOrDefault(key: Int, defaultValue: T)
带默许值的读值这个办法和
HashMap
的getOrDefault()
相似androidstudio安装教程,当获取的值为null时数据结构,就回来默许值:private fun test5() { val sparseArray1: SparseArray<String> = SparseArray<String>() sparseArray1.getOrDefault(10, "null") }
-
Sparse数据结构c语言版Array<T>.getOrElse(key: Int, defaultValue: () -> T)
带默许函数kotlin为什么流行不起来类型回来值的读值这个和上面的
getOrDefault()
比较像,只不过供给默许值的不再是一个固定的具体类型Kotlin的值,而是一个灵活的函数类型,咱们能够在这个函数类型变量是什么意思中进行额外的逻辑编写:private fun test5() { val sparseArray1: SparseArray<String> = SparseArray<String>() sparseArray1.getOrElse(10) { val tmp = "哈哈哈${sparseArray1.size}" tmp } }
-
SparseArray<kotlin为什么流行不起来T>.isEmpty()
判别调集是否为空的 -
SparseAAndroidrray<T>androidstudio安装教程.remove(key: Int, value变量名的命名规则: T)
移除指定key-value
-
SparseArray&l数据结构严蔚敏t;T>.forEach(action: (key: Int, value: T) -> Unit)
遍历运用:
private fun test5() { val sparseArray1: SparseArray<String> = SparseArray<String>() sparseArray1.forEach { key, value -> //履行操作 } }
-
SparseArray<T>.kkotlin是什么eyIterator()
遍历键值key
这个办法会回来一kotlin语言个迭代器,这样咱们就能够运用
for in
来遍历键值keykotlin是什么
了kotlin怎么读:private fun test5() { val sparseArray1: SparseArray<String> = SparseArray<String>() for (key in sparseArray1.keyIterator()) { //履行操作 } }
自定义迭代器就能够协助咱们完成通过
for in
关键字遍历数据结构c语言版严蔚敏第二版答案,具体的能够参考我之前写的一篇文章:你需求懂的Kotlin开发技巧之八#运算符重载for in
。 -
SparseArray<T>.valueIterator()
遍历value运用起来和上面的
keyIterator()
办法相似。
Pair<F, S>
系列效率符号
-
componentX()
解构这也是一个
operator
润饰的运算符重载函数,关于这个解构
,我不太该怎么去用语言来描述,大家直接看下运用吧:private fun test6() { val pair = Pair(10, "ha") val (key, value) = pair }
便是能够直接将这个目标的内部效率是什么意思特点赋值给部分声明的变量,如果你只运用key或value,能够将不想要解构的特点运用
_
替代:kotlin为什么流行不起来val (key , _) = pair //只运用android是什么手机牌子key
这个结构的扩展办法是专门给
Java
(包含android和androidX包下的)的Pair
目标供给的,而Kotlin
自己完成的Pair
是不需求的,由于其声明的Pair
目标便是一个data class
,而data class
会默许给咱们生成解构的办法:反编译成java代码就能够看到生成的
componentX()
系列办法。 -
java
与kotlin
的Pair
彼此转换
-
toKotlinPair
将androidx包
的Pair
目标转成Kotlin
的Pair效率是什么意思
目标 -
toAndroidXPair
将kotlin
的Pair
目标转成androidx包
的Pair
目标 -
toKotlinPair
将android包
的Pair
目标转成Kotlin
的Pair
目标 -
toAndroidPair
将kotlin
的Pair效率高发票查验
目标转成a数据结构与算法ndroid包
的Pair
目标
总结
具体的源码请自行参考core-ktx
包下的Sparse数据结构c语言版第二版课后答案Array.kt
、Pair.k效率的英文t
、SparseXXXArray.kt
等文件源码。接下来就准备研讨下core-ktx
的graphics
包下的关于Vi变量值ew
操作的一些扩展东西了(好多好变量英语多类):
看下能为咱们常见的View
开发带来哪些便当,请您敬请期待吧!!
我正在参加技能社区创作者签约计划招募活动,点击链接报名投稿。