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")
}
相关推荐
iMonster1 分钟前
React 组件的组合模式之道 (Composition Pattern)
前端
呐呐呐呐呢9 分钟前
antd渐变色边框按钮
前端
PfCoder24 分钟前
WinForm真入门(20)——StatusStrip控件解析
开发语言·windows·c#·winform·statusstrip
元直数字电路验证28 分钟前
Jakarta EE Web 聊天室技术梳理
前端
wadesir31 分钟前
Nginx配置文件CPU优化(从零开始提升Web服务器性能)
服务器·前端·nginx
牧码岛32 分钟前
Web前端之canvas实现图片融合与清晰度介绍、合并
前端·javascript·css·html·web·canvas·web前端
灵犀坠33 分钟前
前端面试八股复习心得
开发语言·前端·javascript
9***Y4835 分钟前
前端动画性能优化
前端
网络点点滴36 分钟前
Vue3嵌套路由
前端·javascript·vue.js
牧码岛1 小时前
Web前端之Vue+Element打印时输入值没有及时更新dom的问题
前端·javascript·html·web·web前端