Kotlin开发知识(二)

高阶函数

传入或者返回函数的函数

1.常见高阶函数

forEach
   val list = listOf(1,2,3)
   list.forEach(::println)
map
    val list = listOf(1,2,3)
    val newList = list.map {
        it*2+1
    }
    newList.forEach(::println)
flatMap
    val mlist = listOf(
            1..20,
            2..5
    )
    val flatList = mlist.flatMap{
            it.map {
                "No. $it"
            }
    }
    flatList.forEach(::println)
reduce

累积数据处理

  val mlist = listOf(
        1..20,
        2..5
   )
   val flatList = mlist.flatMap{ it }
   println(flatList.reduce{ acc,i -> acc + i })
fold

添加初始值

  (0..6).map(::factorial).fold(5){acc, i ->  acc+i}

  //n的阶乘
  fun factorial(n:Int):Int{
      if (n==0) return 1
      return (1..n).reduce{acc, i -> acc*i }
  }
filter
  println((0..6).map(::factorial).filter { it%2 == 1 })
takeWhile

当遇到不符合条件的退出

  println((0..6).map(::factorial).takeWhile { it%2 == 1 })
let/apply
  data class Person(val name:String, val age:Int){
      fun work(){
          println("$name is working!!")
      }
  }
  fun main(args: Array<String>) {
      findPerson()?.let { (name, age)->
          println(name)
          println(age)
      }
      findPerson()?.apply { 
          work()
          println(age)
      }
  }
  fun findPerson():Person?{
      return null
  }
with
    val br = BufferedReader(FileReader("hello.txt"))
    with(br){
        var line:String?
        while (true){
            line = readLine()?:break
            println(line)
        }
        close()
    }

2.尾递归优化

  • 递归的一种特殊形式
  • 调用自身后物其他操作
  • tailrec关键字提示编译器尾递归优化
  • 尾递归与迭代的关系
//尾递归
tailrec fun findListNode(head:ListNode?, value:Int):ListNode?{
    head?:return null
    if (head.value == value) return head
    return findListNode(head.next, value)
}
//非尾递归
fun factorial(n:Long):Long{
    return n* factorial(n-1)
}

3.闭包

  • 函数运行的环境
  • 持有函数运行状态
  • 函数内部可以定义函数,也可以定义类
//fun add(x:Int) = fun(y:Int) = x+y

fun add(x:Int):(Int)->Int{
    return fun(y:Int):Int{
        return x+y
    }
}

4.函数复合

val add5 = {i:Int -> i+5}
val multiplyBy2 = {i:Int -> i*2}

infix fun <P1, P2, R> Function1<P1, P2>.andThen(function:Function1<P2,R>):Function1<P1,R>{
    return fun(p1:P1):R{
        return function.invoke(this.invoke(p1))
    }
}

fun main(args: Array<String>) {
    println(multiplyBy2(add5(8)))

    val infixFun = add5 andThen multiplyBy2
    println(infixFun(8))
}

5.颗粒化

  • 简单说就是多元函数变换成一元函数调用链
fun log(tag:String, target:OutputStream, message:Any?){
    target.write("[$tag]$message\n".toByteArray())
}

//颗粒化
fun log(tag:String)
    = fun(target:OutputStream)
    = fun(message:Any?)
    = target.write("[$tag]$message\n".toByteArray())


fun main(args: Array<String>) {
    log("benny", System.out, "helloWorld")
    log("benny")(System.out)("HelloWorld Again!")
}

6.偏函数

  • 传入部分参数得到的新函数
fun log(tag:String, target:OutputStream, message:Any?){
    target.write("[$tag]$message\n".toByteArray())
}

fun main(args: Array<String>) {
    log("benny", System.out, "helloWorld")
    
    val consoleWithTag = (::log.curried())("benny")(System.out)
    consoleWithTag("Hello World Again Again!")
    consoleWithTag("Hello World Again Again Again!")
}

fun <P1,P2,P3,R> Function3<P1,P2,P3,R>.curried()
= fun(p1:P1) = fun(p2:P2) = fun(p3:P3) = this(p1, p2, p3)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1.函数引用 kotlin中函数引用跟c++中的方法指针很相似,函数引用可以像其他类型的引用一样作为方法的参数和返...
    懒癌患者2018阅读 10,083评论 0 7
  • 工作占了我们生活的大部分时间,一天起码有八个小时我们都是在工作的状态,一天有两顿饭可能都是和同事一起吃的,有的单身...
    AMU_PLA阅读 2,555评论 0 2
  • 今天我们要讲的这家公司是Uber,可能很多人都觉得,Uber不就是美国版的滴滴么,有什么好讲的?首先问你一个问题:...
    王先森科技日记阅读 5,668评论 0 0
  • 今天是我们阅读组的课堂研讨,很感谢立律和娟儿承担了这次的课堂教学任务,让我没那么赶,两位亲真的辛苦了。 ...
    言小小红阅读 3,142评论 0 1
  • 我们彼此的温暖融化那一道道刺入骨髓的寒殇搀扶着走下去无惧路远马亡在冰冷铁轨终点一起摄入零度日光最后的阴影由我来埋葬
    枫流阅读 1,243评论 0 2

友情链接更多精彩内容