lamba两种方式,其他的和java中的可变参数一致。...这里等待后面具体来看什么时候非内联 在 Kotlin 中,我们可以只使用一个正常的、非限定的 return 来退出一个命名或匿名函数。...这意味着 lambda 表达式中的 return 将从包含它的函数返回,而匿名函数中的 return 将从匿名函数自身返回。...闭包 Lambda 表达式或者匿名函数(以及局部函数和对象表达式) 可以访问其 闭包 ,即在外部作用域中声明的变量。...可以实现dsl风格的代码全靠它 Kotlin 提供了使用指定的 接收者对象 调用函数字面值的功能。 可以调用该接收者对象上的方法而无需任何额外的限定符,可以任意调用接受者的方法和属性。
本文简单谈下Kotlin中的函数,包括表达式函数体,命名参数,默认参数,顶层函数,扩展函数,局部函数,Lambda表达式,成员引用,with/apply函数等。...1.表达式函数体 通过下面这个简单的例子看下函数声明相关的概念,函数声明的关键字是fun,嗯,比JS的function还简单。 Kotlin中参数类型是放在变量:后面,函数返回类型也是。...4.顶层函数 不同于Java中函数只能定义在每个类里面,Kotlin采用了JavaScript 中的做法,可以在文件任意位置处定义函数,这种函数称为顶层函数。...,在Java中可以抽取出独立的函数,但这样有时候对整体结构并不太好,Kotlin提供了局部函数来解决这个问题。...Lambda中的this引用指向的是包围它的类。 如果在Lambda中要用到常规意义上this呢?这个就需要带接收者的函数。看下比较常用的两个函数with和apply。
Kotlin中的内联函数还是挺好玩的 为什么需要内联函数? lambda 表达式会被正常地编译成匿名类。这表示每调用一次 lambda表达式,一个额外的类就会被创建。...内联函数使用 inline 修饰符标记,内联函数在 被使用的时候编译器并不会生成函数调用的代码,而是使用函数实现的真实代码替换每一次的函数调用 内联函数如何运作?...当一个函数被声明为 inline 时,它的函数体是内联的一一换句话说,函数体会被直接替换到函数被调用的地方,而不是被正常调用。...中Int、Long、Double都继承自Number,但是,如果我们在调用上面的函数时,传入了Array,这样是会报错的!!...因为 kotlin中在调用函数时要求参数类名必须完全一致!! 对于上面的函数,如果我们想既可以接收 Array, 也可以接收Array, 那么就可以定义一个具体化类型参数的内联函数.
前言 在Kotlin中的源码标准库(Standard.kt)中提供了一些Kotlin扩展的内置函数可以优化kotlin的编码。Standard.kt是Kotlin库的一部分,它定义了一些基本函数。...本文主要记录kotlin中let、apply、run、also、with等函数的用法和区别,下面话不多说了,来一起看看详细的介绍吧 0. let val a = "hello,kotlin".let{...= block(this) 解释:调用 “hello,kotlin”的let函数,it在作用域中替代该对象(hello,kotlin),默认返回函数最后一行 1. apply val a = "hello...指定的T作为闭包的receiver,使用参数中闭包的返回结果。...以上,注意阅读Kotlin相关高阶函数的源码时候,如果函数中最后一个参数为闭包,那么最后一个参可以不写在括号中,而写在括号后面,如果只有一个参数,括号也可以去掉。
Kotlin中的泛型和java中的十分类似都是用T表示泛型 kotlin中使用 T 表示泛型。...在定义泛型函数时需要在 fun 后面加入 , 然后指明某个参数的类型为 T 泛型函数的定义: //Kotlin中允许定义全局函数,将函数定义在kt文件中,然后全局可调用 fun appendString...//遍历可变数组,然后拼接 str = "$str${item.toString()}," } return st } 泛型函数的调用...btn_vararg_generic.setOnClickListene { tv_function_result.text = when (count % 3) { //在定义泛型函数时...appendString("小于10的素数", 2, 3, 5, 7) else -> appendString("花钱的日子", 5.20, 6.18
10的 ArrayList 和 transform 函数,在 mapTo 方法中,对集合进行迭代,然后将进行变换后的数据添加到新的集合中,最后返回新的集合。...map 和 flatMap 的主要区别就是在于传入的函数的返回值,一个是任意对象,一个是实现了 Iterable 接口的对象 reduce 例子:打印集合中的元素之和 1fun main(args:...中创建新的集合 ArrayList ,将 ArrayList 和 predicate 函数一并传递给 filterTo 函数。...疑惑点 函数定义中 `T.() -> Unit` 和 `() -> Unit` 的区别 我们一般定义函数都会选择定义 1fun T.makeMoney2(block: () -> Unit)...里的this代表的是自身实例,而 ()->Unit 里,this代表的是外部类的实例 感谢 [Kotlin中,函数作为参数,T.()->Unit 和 ()->Unit 的区别][https://www.jianshu.com
前言 在Kotlin中,高阶函数是指将一个函数作为另一个函数的参数或者返回值。如果用f(x)、g(x)用来表示两个函数,那么高阶函数可以表示为f(g(x))。...Kotlin为开发者提供了丰富的高阶函数,比如Standard.kt中的let、with、apply等,_Collectioins.kt中的forEach等。...Kotlin 使用类似 (Int) – String 的一系列函数类型来处理函数的声明,这些类型具有与函数签名相对应的特殊表示法,即它们的参数和返回值: 所有函数类型都有一个圆括号括起来的参数类型列表以及一个返回类型...常用高阶函数 Kotlin提供了很多高阶函数,这里根据这些高阶函数所在文件的位置,分别进行介绍,先来看一下常用的高阶函数,这些高阶函数在Standard.kt文件中。...区别是T.run()是作为泛型T的一个扩展函数,所以在传入的lambda表达式中可以使用this关键字来访问这个泛型T中的成员变量和成员方法。
很多同学刚上手使用Kotlin知道它有针对Java NullPointerException的管理,而在Kotlin中?和!!...不懂就问百度呀,确实有人解释它们的区别,比如: 这是输入 "kotlin ?和!!" 搜索到的百度第一条答案,确实这位说的没错。...大概意思是,当roomList为null的时,它的size返回就是"null",但是"null"不可以和int值比大小,所以编译器建议我们写成roomList?.size!! > 0。...当然Kotlin不会让程序出现这种啰嗦的代码,所以里面提供了对象A ?: 对象B表达式,并且取消了Java中的条件表达式 ? 表达式1 : 表达式2这个三元表达式。 ?...和?:基本上能避免程序中出现的所有NullPointerException。
在做kotlin开发中,经常看到一些系统函数里,用函数作为参数,但是又和我们自己写的不太一样 大概是这样子的: public inline fun T.apply(block: T....我们这里来看一下文档是怎么说的, ? 输入图片说明 我们这里看一下画原谅色线的部分,原来这里作用就是可以this代表的对象的不同。...---- 我们首先定义两个函数: fun T.afterMersure(f: T.() -> Unit) { } fun T.afterMersure2...(f: () -> Unit) { } 这两个函数是用于,View测量完成之后的回调。...,这两个函数唯一的区别就是T.()-Unit与()->Unit的区别,我们调用时,在代码块里面写this,的时候,根据代码提示,我们可以看到,连个this代表的含义不一样,T.()->Unit里的this
OnClickListener接口只有一个抽象方法,这种接口在kotlin中被当作函数式接口,或者SAM接口,SAM代表单抽象方法,类似的还有像Runnable和Callable这样的函数式接口....SAM构造方法:显式地把lambda转换成函数式接口. 在有的方法中需要返回一个函数式接口,不能返回一个lambda, 可以用SAM构造方法把它包装起来....如下 fun createAllDoneRunable() : Runnable{ return Runnable{ println(“All done”) } } SAM函数名称和底层函数式接口的名称一样...SAM构造方法只接收一个参数-一个被用作函数式接口单抽象方法体的lambda,并返回一个接口类的实例....另外除了返回值通过lambda创建函数式接口外,也可以把lambda生成的函数式接口放在一个变量中,如下 val listener = OnClickListener{ view - val text
let、with、run、apply、also、takeIf、takeUnless、repeat函数的使用 kotlin Standard.kt文件中,提供了一些内联函数,这些内联函数可以减少代码量,...观察函数的定义可以发现,run函数为一个扩展函数,而其接受的参数和with函数第二个参数相同,run函数可以理解为let函数和with函数的结合体。...总结: 这里我们总结对比一下这五个函数,这五个函数的特性非常简单,区别也无非是接受的参数和返回的类型不同。...其中,对于with,run,apply接收者是this(可以省略),而let和also则使用it接受且不可s省略对于; 对于with,run,let返回值是返回值是函数里面最后一行,或者指定return...结语: Kotlin Standard.kt中的标准库函数已基本讲解完毕,其中涉及到了高阶函数和lambda函数,相关知识可通过官方文档学习,同时建议读者将每个函数都实际敲一遍,并通过查看他们编译后的
Kotlin 中的 appy和with方法 apply apply:Calls the specified function block with this value as its receiver...,它接受一个参数block,类型为 T.() -> Unit ( function-with-receiver) 在apply的函数体内,调用了传入的block这个函数,然后返回调用apply函数的对象实例...它的实现代码也只有一行 public inline fun with(receiver: T, block: T.() -> R): R = receiver.block() with为高阶函数...with返回的类型为R,和block的返回类型相同 fun getPersonFromDeveloper(developer: Developer): Person { return with(...is a receiver in kotlin What is a purpose of Lambda's with Receiver?
下面我们来说说 Kotlin中的高阶函数 Kotlin 不是纯粹的面向对象语言, Kotlin 的函数也是一等公民,因此函数本身也具有自己 的类型 。...函数类型就像前面介绍的数据类型一样,既可用于定义变量,也可用作函数的形参类 型,还可作为函数的返回值类型 使用函数类型 Kotlin 的每个函数都有特定的类型,函数类型由函数的形参列表、 ·>和返回值类型组成...fun test() { .... } 该函数的形参列表、 ·>和返回值类型为() ->Unit 或(),这就是该函数的类型 。...使用函数类型作为形参类型 Kotiin 支持像使用其他类型一样使用函数类型,因此完全可以在函数中定义函数类型的形 参 例子 //定义函数类型的形参,其中 fn 是( Int )→ Int 类型的形参 fun...着每次调用函数时都可动态传入一个函数,随着实际传入函数的改变,就可以动态改变 map() 函数中的部分计算代码 。
中的集合高阶函数,进行下讲解,降低大家阅读源码的难度,下面看几个用的比较多的高阶函数使用。...,当前的累积值和集合中的下一个元素。...,只能从集合中获取,所以,Kotlin还提供了更加通用的高阶函数——fold,代码如下所示。...❞ 由此可见,在Kotlin中,reduce实际上是一个不完善的高阶函数,大部分时候,都应该避免使用它,而应该使用flod来代替,而且,要注意的是,在其它语言中,例如JavaScript中,它的reduce...函数,实际上和Kotlin的fold函数的逻辑是一样的,而不是Kotlin中reduce的实现。
不管String类是用Java、Kotlin,或者像Groovy的其他JVM语言编写的,只要它会编译为Java类,就可以为这个类添加自己的扩展。 在这个扩展函数中,可以像其他成员函数一样用this。...Kotlin允许用和导入类一样的语法来导入单个的函数: import strings.lastChar //星号导入 import strings.* 3.3.2在Java中调用扩展函数 其实,扩展函数是静态函数...调用扩展函数,不会创建适配的对象或者任何运行时的额外消耗。 这使得从Java中调用Kotlin的扩展函数变得非常简单:调用这个静态函数,然后把接收对象作为第一个参数传进去即可。...假设它声明在一个叫做StringUtil.kt的文件中: char c = StringUtil.lastChar("Java"); 和Kotlin版本比较起来,可读性略差。...3.3.4不可重写的扩展函数 扩展函数并不是类的一部分,它是声明在类之外的。扩展函数并不存在重写,因为Kotlin会把它们当做静态函数对待。
在以前,因为学过一段时间Kotlin(并没有实际开发中用过),很多东西都忘记了,但是kotlin的代码看起来其实和Java没什么区别,感觉都差不多。所以不要认为 Kotlin 很难学。...首先,什么是内联函数 inline? Kotlin的内联函数属于Kotlin的高级特性之一,使用起来也非常简单。...没加 inline 之前 加上 inline 之后 解释就不用多说了吧,kotlin 自动帮我们将方法在编译期就加在了相应的调用处,免除了 java 中的入方法栈与退栈。...非局部返回标记 为了不让lamba表达式直接返回内联函数,所做的标记 相关知识点:我们都知道,kotlin中,如果一个函数中,存在一个lambda表达式,在该lambda中不支持直接通过return...reified java中,不能直接使用泛型的类型 kotlin可以直接使用泛型的类型 inline fun startActivity() { startActivity(Intent(this
package com.easy.kotlin // 简单好用的 Kotlin 类型别名, 我们使用 G,F,H 声明了3个函数类型(有点类似Java 中的接口类型的概念) typealias G =...value.length}") } println(foo(1, { it -> it + 1 })) println(foo(10, { it -> it * it })) } // 简单直接的函数定义...= 0 fun g(s: String) = s.length // 简单优雅的高阶函数定义(复合函数): compose(f, g) = f(g(*)) fun h(g: G, f: F): H {...return { x -> f(g(x)) } } // 这个foo函数类型是: (Int) -> T, 正好也就是传入的函数参数 transform fun foo(x: Int...---- 非常感谢您亲爱的读者,大家请多支持!!!有任何问题,欢迎随时与我交流~ ----
在Kotlin中,扩展函数是一种非常有用的功能,可以让我们向现有的类添加新的功能,而无需修改类的源代码。在本文中,我们将探讨Kotlin扩展函数的原理和运用,以及如何在Android开发中使用它们。...什么是扩展函数? 扩展函数是Kotlin中的一种特殊函数,它允许我们向一个类添加新的函数,而无需继承或修改这个类的源代码。扩展函数的语法非常简单,只需要在函数名前面加上类名,并用点号隔开即可。...例如,我们可以向Kotlin中的String类添加一个新的函数,用于反转字符串: fun String.reverse(): String { return this.reversed() }...在函数体中,我们调用了SharedPreferences的edit和getBoolean方法。...Kotlin中的一种非常有用的功能,可以让我们向现有的类添加新的功能,而无需修改类的源代码。
Kotlin 能够扩展一个类的新功能而无需继承该类或者使用像装饰者这样的设计模式。 这通过叫做 扩展 的特殊声明完成。 例如,你可以为一个你不能修改的、来自第三方库中的类编写一个新的函数。...在 Android Studio 中,我们可以查看 kotlin 文件的字节码,然后再 Decompile 为 Java 代码。上面我们为 Person 扩展函数转为Java代码后如下。...由此可见,所谓扩展函数并不是真正的在类中增加了一个方法,而是通过外部文件的静态方法来实现,其实就是和Utils类一个道理。...和扩展函数一样,在其他文件中声明如下。...总结 在 Java 中,我们要扩展一个类时,常常是继承该类或者用装饰者模式类似的设计模式来实现,Kotlin 扩展函数和扩展属性为这种需求提供了一种新思路,并且也可以作为 Utils 类的另外一种选择
前言 看了很多博客,才明白了内联的含义,其实最根本的就是将写在别处的代码拷贝到你现在执行的方法中,相当于在一个方法中执行,java的方法执行是需要压栈出栈的对吧,如果是两三个方法那就是两三次的压栈出栈,...为了节省这个操作,提高一定的效率,kotlin就出了这么个函数。...的lambda在函数的调用点是不可用的,只有等到doSomething被内联后,该lambda才可以正常使用。...通过上面的例子,我们对lambda表达式何时被内联做一下简单的总结: 当lambda表达式以参数的形式直接传递给内联函数,那么lambda表达式的代码会被直接替换到最终生成的代码中。...是的,编译器会抛出“Illegal usage of inline-parameter”的错误,这是因为Kotlin规定内联函数中的lambda参数只能被直接调用或者传递给另外一个内联函数,除此之外不能作为他用
领取专属 10元无门槛券
手把手带您无忧上云