Kotlin(十六) 高阶函数的简单应用

高阶函数非常适用于简化各种API的调用,一些API的原有用法在使用高阶函数简化之后,不管是在易用性还是可读性方面,都可能会有很大的提升。

所以我们可以通过高阶函数来使一些API变得更简单更易读。在我们APP存储数据时,通常会用到SharedPreferences 这个API,那么我们现在尝试使用高阶函数来简化它。

简化SharedPreferences

我们之前使用SharedPreferences时,基本需要三步

1.获取Editor对象

2.通过Editor对象存储数据

3.调用apply()方法提交数据,完成存储操作

对应代码如下:

Kotlin 复制代码
    @SuppressLint("CommitPrefEdits")
    fun saveSharedPreferences(saveString: String) {
        val edit = getSharedPreferences("fileName", Context.MODE_PRIVATE).edit()
        edit.putString("editName", "editValue")
        edit.apply()
    }

那我们该如何简化他呢?首先我们可以通过扩展函数的方式,给SharedPreferences扩展一个save函数,并且他还接收一个函数类型,那么save函数就是一个高阶函数了。

代码如下:

Kotlin 复制代码
fun SharedPreferences.save(block: SharedPreferences.Editor.() -> Unit) {
     val editor = edit()
     editor.block()
     editor.apply()
}

调用

Kotlin 复制代码
getSharedPreferences("name",Context.MODE_PRIVATE).save { 
    putString("key","value")
}
相关推荐
米丘10 小时前
React 19.x 的 lazy 与 Suspense
前端·javascript·react.js
如果超人不会飞10 小时前
TinyVue Grid 表格 fetchData 完全指南:从入门到精通
前端
kyriewen10 小时前
手写虚拟DOM后,我反问面试官:key为什么不能用index?
前端·react.js·面试
一然明月10 小时前
qt基本用法
开发语言·qt
Doris_202310 小时前
说一说ESLint+Prettier生效的原理
前端·设计模式·架构
hef28810 小时前
Prism图形设计从入门到精通:外观设置、图层顺序与微调技巧
开发语言
ZC跨境爬虫10 小时前
跟着 MDN 学CSS day_21:(图像溢出控制与表单元素样式定制)
前端·javascript·css·ui·交互
长谷深风11110 小时前
Java 面试高频:反射机制与异常体系全面解析
java·开发语言·面试·exception·java 反射·java 异常·class 对象
卷帘依旧10 小时前
微前端解决方案-qiankun
前端
moshuying10 小时前
你做的,比汇报出来的多得多
前端