kotlin匿名函数(重点)
1,匿名函数 {参数-> 参数 隐式认为最后一行是返回值(若有返回 }
2,变量类型为一个匿名函数 val hhh:()->String={ val hh=“hhhhh” “daxiobg”$hh }
hhh类型为字符串 结果为匿名函数计算的结果 这样简单的运算就可以不用再去写一个具名函数 通过匿名函数作为变量类型,可以在给变量赋值前进行一些简单的运算,不用具名函数
3,匿名函数参数类型放在匿名函数定义中 参数放在函数中 eg val hhh:(String ,int)->String={name,age-> 运算 }
4, 如果匿名函数参数只有有一个 可以用it关键字代替 很方便
5,匿名函数对kotlin很重要 函数式编程 很多情况下用
6, 如果以匿名函数作为变量类型 那么就有类型推断 匿名函数返回值类型都不用写了 val hhh={a:String,b:int -> } a b也可以类型推断 之前()里的类型 就不用写了。
7,匿名函数就是lambda.还可以作为其他函数的参数 eg val a={aa,bb-> } showda(name:String,a:(String,int)->String){ println(a(nsme,4)) } 调用 showsa(“dbdn”,a) 简写推荐 看着像定义函数,其实时调用运行函数 showda(“dhjd”){ 直接lamda表达式 不用间接参数a. }
8,如果a.count({ }) 如果{}是唯一参数 ()可以去掉 a.count{}
注意:其实传入一个匿名函数,这就给了开发者很大的灵活性,用最少代码,写最多的功能。例如 showsa函数,通过传入的匿名函数不同,我们的showsa函数就实现不同的效果(对字符串的处理,数值处理等等),通过一个匿名函数,让shiwsa的功能有了很多可能,这就是对showsa函数进行了抽象
9、函数内联 使用lamda表达式会创建很多对象,影响性能 那么用使用lamada 的函数使用内联 inline 就可以解决这个问题(做了一个复制操作) eg 上个例子 定义时 private inliane showda(name:String,a:(String,int)->String){ println(a(nsme,4)) }
10,函数引用 把lamada表达式改为具名函数,然后调用时 showda(“djdj”,::dis) 两个冒号 加函数名就行
11,函数类型作为返回类型 和参数类型有点像 的这里是方法 有return fun aa():(String)->String{ 一些其他变量,下面匿名函数可以使用,闭包 return {name:String-> } } 调用 val a=aa() print(a(“aa”)) 注:定义时可以不用变 和上例一样.还涉及kotlin闭包 作用域共享 函数式编程 。可能平时写业务感觉没必要,但写框架就能看出其意义非凡,因为传入参数不同,返回的是一个函数,这就是抽象
12,闭包 .匿名函数可以引用定义自身的作用域里的变量。lambada就是闭包。 java里面,有天然的包和class来防止变量冲突,但是kotlin有脚本语言特性,可以没有class,只写函数,那么为了防止变量冲突,就出现一些函数,该函数里面包含许多函数,那么这个函数就相当于确定变量作用域,有点像包。
13,能接收函数或者返回函数的函数又叫做高级函数,被广泛运用于函数式编程中,和js有点像。
14,kotlin的匿名函数 lamabda 与java匿名内部类比较。java匿名内部类 一般是 创建一个接口 interface A a { fun aa()}, 方法定义时 fun b(参数1,A a){a.aa() } 调用方法时 b(参数,new A(){}) 直接new 一个接口 重写方法 。这样做的好处就是,提前知道有那么一个方法,但是具体实现还是靠重写方法定制,这就是匿名内部类。那么kotlin中匿名函数的好处就是 减少了一些模式化代码的书写,什么接口啥的,都没了。但是坏处就是。可读性不行(对于不熟的娃来说)。
总结:就匿名函数来说,无论是作为变量类型,还是函数变量,作为函数返回类型看,都显示出其特别的灵活性,减少模式化,解放开发者。但是,lamabda的可读性比较差(对于接触较少的开发者) 高阶函数使用博客
https://www.jianshu.com/p/bbecc721de61
|