Kotlin函数式编程超详细介绍

目录
  • 1.函数式编程
  • 2.函数类别
  • 3.变换函数(transform)
  • 4.过滤函数(filter)
  • 5.合并函数(combine)

1.函数式编程

我们都知道java是面向对象编程范式。在java的世界,一切皆对象。

函数式编程范式是有抽象数学的lambda演算发展而来,主要依赖高阶函数返回的数据,这些高级函数专用于处理各种集合,可以方便的联合多个函数构建链式操作,以创建复杂的计算行为。

所谓高级函数就是以函数为参数或返回值是函数的函数。这点,前面的文章,有过简单介绍。

2.函数类别

一个函数式应用通常由这三大类组成,变化transform、过滤filter、合并combine。每类函数都针对集合数据类型设计,目标是产生一个最终结果。函数式编程用到的函数生来都是可以组合的。通过简单函数的组合来实现复杂的计算。

3.变换函数(transform)

变换函数会遍历集合内容,以值参的形式传入变换器函数,变换每一个元素,然后返回包含已修改元素的集合,传给链上的其他函数。最常用的两个变换函数是map和flatMap

map函数:

1)map变换函数,遍历集合没一个元素,通过变换器,变换成新的元素,并存入新的集合,然后返回变换后的集合作为链上下一个函数的输入。

2)map转换函数转换后的集合和集合,大小是一样的,并且不会改变原集合的内容。

简而言之,就是讲一个就集合变换成一个新集合

示例:list集合经过map转换器后,变成了Fruit集合

fun main() {
    val list = listOf("Apple","Banana","pear")
    val fruits = list.map {
        Fruit(it)
    }
    list.forEach { println(it) }
    fruits.forEach {
        println(it.name)
    }
}

map函数定义

1)调用者Iterable<T>是一个集合类型,集合元素是T类型,返回值是: List<R>,集合元素是R类型

2).map(transform: (T) -> R) map接收一个transform匿名函数,匿名函数的参数是T,返回值是R

public inline fun <T, R> Iterable<T>.map(transform: (T) -> R): List<R> {
    return mapTo(ArrayList<R>(collectionSizeOrDefault(10)), transform)
}
public inline fun <T, R, C : MutableCollection<in R>> Iterable<T>.mapTo(destination: C, transform: (T) -> R): C {
    for (item in this)
        destination.add(transform(item))
    return destination
}

flatMap函数:

flatMap操作的是集合的集合,将多个集合中的元素合并后,返回一个包含所有元素的集合。

fun main() {
    val list = listOf("Apple","Banana","pear")
    val list2 = listOf("orange","watermelon","lemon")
    val newFruit = listOf(list,list2).flatMap { it }.map {
        Fruit(it)
    }
    newFruit.forEach {
        println(it)
    }
}

4.过滤函数(filter)

filter过滤函数接收一个predicate函数。如果predicate函数返回为true,受检元素会添加到过滤后的新集合中,如果为fasle,则受检元素就会被移除新集合。

通俗的讲,就是讲原集合按照过滤函数给定的条件,形成一个新的集合。

示例:在集合元素中,包含"a"的元素,形成新的集合。

fun main() {
    val list = listOf("Apple","Banana","pear")
    val newList = list.filter { it.contains("a") }
    newList.forEach {
        println(it)
    }
}

flat和filter配合使用示例:

fun main() {
    val list = listOf("Apple","Banana","pear")
    val list2 = listOf("orange","watermelon","lemon")
    val newFruit = listOf(list,list2).flatMap { it }.map {
        Fruit(it)
    }.filter {
        it.name.contains("a")
    }
    newFruit.forEach {
        println(it)
    }
}

过滤偶数:

 val numbers = listOf(1, 2, 3, 4, 5, 6, 7, 8, 9)
    val newList = numbers.filter {
        it % 2 == 0
    }
    newList.forEach {
        println(it)
    }

5.合并函数(combine)

zip函数:用来合并两个集合,形成一个新的键值对的集合。可以把这个集合转成一个map集合

fun main() {
    val list = listOf("Apple", "Banana", "pear")
    val list2 = listOf("orange", "watermelon", "lemon")
    val numbers = listOf(0,1, 2, 3, 4, 5)
    val newFruit =  numbers.zip( listOf(list, list2).flatMap { it } ).toMap()
        newFruit.forEach { index, value ->
        println("$index:$value")
    }
}

到此这篇关于Kotlin函数式编程超详细介绍的文章就介绍到这了,更多相关Kotlin函数式编程内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Kotlin扩展函数超详细介绍

    目录 1.扩展函数 2.infix 关键字 3.扩展函数文件 4.重命名扩展函数 1.扩展函数 1)当我们没法接触某个类的定义,或者某个类没有用open修饰无法继承时,我们可以通过扩展函数,来实现该类功能的扩展.扩展函数,可以扩展自定义类.String类以及kotlin标准库中的其他类. 2)定义扩展函数和定义一般函数差不多.唯一的不同就是,定义扩展函数时,除了函数定义外,还需指定给哪个类进行扩展.如:fun String.addExtention() = "Kotlin: ".plu

  • Kotlin标准库函数使用分析及介绍

    目录 1.apply 函数 2.let 函数 3.run函数 4.with 函数 5.also 6.takeIf 7.takeUnless 1.apply 函数 apply函数可以看做是一个配置函数.针对apply函数的调用者做一些配置,并把调用者返回. 示例:下面apply的调用者是file,调用完之后,返回的还是file,并在apply函数中,针对file做了一些配置. val file = File("d:\\hello.txt").apply { setWritable(tru

  • Kotlin函数使用示例教程

    目录 我们先看看简单的函数 我们写一个求和函数 函数头 函数体 调用函数非常简单 反编译Java源代码步骤 接下来我们来看看匿名函数 这是接口的声明 我们先看看简单的函数 // 前面的文章我们了解到它是入口函数 fun main() { } // 对应的Java 语言,熟悉的Java 的朋友会发现,哈哈,这就是一个Java静态方法 // 我们通过两种语言的对比,能够对函数有一个更好的理解 public static final void main() { } // 如果没有 Java 基础,不适

  • Kotlin 嵌套函数开发技巧详解

    目录 1.嵌套函数 2.@JvmOverloads快捷实现函数重载 3.延迟初始化lateinit var 4.@JvmField减少属性set和get方法的生成 1.嵌套函数 业务开发中,我们可能会遇到这样一个场景:一个函数只会被某一处多次调用,且不想让这个函数在该类的其他地方调用,这个时候就需要对这个函数的访问性进行进一步限制. private是无法满足的,这个时候我们就可以使用嵌套函数提供更好的封装: fun test1() { //被限制访问行的函数 fun test2(content:

  • Kotlin函数式编程超详细介绍

    目录 1.函数式编程 2.函数类别 3.变换函数(transform) 4.过滤函数(filter) 5.合并函数(combine) 1.函数式编程 我们都知道java是面向对象编程范式.在java的世界,一切皆对象. 函数式编程范式是有抽象数学的lambda演算发展而来,主要依赖高阶函数返回的数据,这些高级函数专用于处理各种集合,可以方便的联合多个函数构建链式操作,以创建复杂的计算行为. 所谓高级函数就是以函数为参数或返回值是函数的函数.这点,前面的文章,有过简单介绍. 2.函数类别 一个函数

  • C语言 超详细介绍与实现线性表中的带头双向循环链表

    目录 一.本章重点 二.带头双向循环链表介绍 2.1什么是带头双向循环链表? 2.2最常用的两种链表结构 三.带头双向循环链表常用接口实现  3.1结构体创建 3.2带头双向循环链表的初始化  3.3创建新节点 3.4尾插 3.5打印链表 3.6头插 3.7尾删 3.8头删 3.9查找data(返回data的节点地址) 3.10在pos位置之前插入节点 3.11删除pos位置的节点 四.实现接口总结 五.在线oj训练与详解 一.本章重点 带头双向循环链表介绍 带头双向循环链表常用接口实现 实现接

  • Kotlin扩展方法超详细介绍

    目录 前言 一.扩展方法 1.扩展方法的原型 2.扩展方法的使用 二.Kotlin扩展方法实现原理 三.泛型扩展方法 四.扩展属性 五.为伴生对象添加扩展 六.Kotlin 中常用的扩展 七.案例 前言 在这一节为大家继续带来 Kotlin 中的一些高级的内容:Kotlin 中的 Kotlin 扩 展(Extensions). Kotlin 能够扩展一个类的新功能而无需继承该类. 例如,你可以为一个你不 能修改的来自第三方库中的类编写一个新的函数. 这个新增的函数就像那个 原始类本来就有的函数一

  • Python Socket 编程知识点详细介绍

    目录 一.导入Socket模块 二.Socket基本用法 1.建立一个简单的Socket连接 2.协议对应端口 3.Socket函数 4.套接字函数 5.一个简单的客户端与服务端交互 三.总结 前言: Socket又称为套接字,它是所有网络通信的基础.网络通信其实就是进程间的通信,Socket主要是使用IP地址,协议,端口号来标识一个进程.端口号的范围为0~65535(用户端口号一般大于1024),协议有很多种,一般我们经常用到的就是TCP,IP,UDP.下面我们来详细了解下Socket吧. 一

  • Android超详细介绍自定义多选框与点击按钮跳转界面的实现

    总程:在avtivity_main.xml设计5个控件,btn1-5,点击btn1弹出一个多选对话框,点击按钮btn1弹出一个多选框可选择你喜欢的打野英雄,点击btn2跳转到activity_main2界面(就是图片,不可选择)设计思路流程:在activity_main.xml布局界面,总体在头目录进行垂直排列,然后镶嵌5个水平的线性布局(左是ImageView,右边是Button按钮)由于5张图的大小在一个屏幕显示不出来,所以添加一个ScoveView滚动,以使所有资源可以看到! 在MainA

  • C语言 超详细介绍与实现线性表中的无头单向非循环链表

    目录 一.本章重点 二.链表介绍 三.无头单向非循环链表常用接口实现 3.1动态申请一个节点 3.2单链表打印 3.3单链表尾插 3.4单链表的头插 3.5单链表的尾删 3.6单链表头删 3.7单链表查找 3.8单链表在pos位置之前插入x 3.9单链表删除pos位置的节点 四.在线oj训练 4.1移除链表元素(力扣) 4.2反转单链表(力扣) 一.本章重点 无头单向非循环链表介绍 无头单向非循环链表常用接口实现 在线oj训练 二.链表介绍 概念:链表是一种物理存储结构上非连续.非顺序的存储结构

  • Java超详细介绍抽象类与接口的使用

    目录 1.抽象类的语法和特性 1.1语法 1.2特性 2.接口的语法和使用 2.1语法 2.2特性 1.抽象类的语法和特性 1.1语法 1.在Java中,一个类如果被abstract 修饰称为抽象类,抽象类中被 abstract 修饰的方法称为抽象方法,抽象方法不用给出具体的实现体. // 抽象类:被abstract修饰的类 public abstract class Shape { // 抽象方法:被abstract修饰的方法,没有方法体 abstract public void draw()

  • Java超详细介绍封装与访问控制修符

    概念:我们在写入一个类的时候,为了保护里边的属性不被随意的调用这是我们可以使用特殊的修饰符进行相应的保护,而这样的话我们似乎只能在该类中调用使用了,出现某些特殊情况时就会无法发调用,虽然挺高了安全性但也降低了灵活性,这个时候我们的包装类就出现了,我们通过对某个方法的进行特殊方法的包装来对其进行相应的调用与赋值.就相当于银行为了保护财产会选择将金钱放进保险柜中来确保其的安全,但是当我们要取钱时,银行就要拿钥匙打开保险柜.修饰符相当于银行的保险柜,封装相当于保险柜的钥匙. 访问修饰符如下: 1) p

  • SpringMVC超详细介绍自定义拦截器

    目录 1.什么是拦截器 2.自定义拦截器执行流程图 3.自定义拦截器应用实例 1.快速入门 2.注意事项和细节 3.Debug执行流程 4.多个拦截器 1.多个拦截器执行流程示意图 2.应用实例 3.主要事项和细节 1.什么是拦截器 说明 Spring MVC 也可以使用拦截器对请求进行拦截处理,用户可以自定义拦截器来实现特定的功能. 自定义的拦截器必须实现 HandlerInterceptor 接口 自定义拦截器的三个方法 preHandle():这个方法在业务处理器处理请求之前被调用,在该方

随机推荐