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")
}
相关推荐
期待のcode几秒前
Java的多态
java·开发语言
王林不想说话33 分钟前
React自定义Hooks
前端·react.js·typescript
heyCHEEMS34 分钟前
Uni-app 性能天坑:为什么 v-if 删不掉 DOM 节点
前端
马致良36 分钟前
三年前写的一个代码工具,至今已被 AI Coding 完全取代。
前端·ai编程
橙某人38 分钟前
LogicFlow 交互新体验:让锚点"活"起来,鼠标跟随动效实战!🧲
前端·javascript·vue.js
借个火er41 分钟前
依赖注入系统
前端
借个火er41 分钟前
项目介绍与环境搭建
前端
gustt42 分钟前
React 跨层级组件通信:从 Props Drilling 到 useContext 的实战剖析
前端·react.js
证能量少女1 小时前
2026大专Java开发工程师,考什么证加分?
java·开发语言
程序猿的程1 小时前
Stock写给前端的股票行情 SDK: stock-sdk,终于不用再求后端帮忙了
前端·javascript·node.js