20170625_kotlin入门_part3

2017-07-15  本文已影响0人  mingmingz

part1

part2

这是入门系列的第三部分,前两章节可以在上面进入

Callable references

Reference to a function

/**
 * "Callable References" or "Feature Literals", i.e. an ability to pass
 * named functions or properties as values. Users often ask
 * "I have a foo() function, how do I pass it as an argument?".
 * The answer is: "you prefix it with a `::`".
 */

fun main(args: Array<String>) {
    val numbers = listOf(1, 2, 3)
    println(numbers.filter(::isOdd))
}

fun isOdd(x: Int) = x % 2 != 0

在kotlin中,方法的参数我们是可以引入一个函数的,怎么引入呢?在函数名前面加"::"

像给出的例子:我们对一个存了数字的list调用filter(),filter()函数中需要的参数是一个predicate(该情景不知道用哪个中文翻译合适,就直接拿原词),该predicate需要返回的值是boolean类型,即我们可以写一个函数来充当带predicate并返回一个boolean,事情好像是应该这么发生,但filter到底怎么就能使用该引用函数呢?点进去看看吧

//filter()函数是Collections类的增强函数,它会去调用本类的增强函数:filterTo(destination: C, predicate: (T) -> Boolean),传了一个新的list对象以及刚刚我们写的predicate过去
public inline fun <T> Iterable<T>.filter(predicate: (T) -> Boolean): List<T> {
    return filterTo(ArrayList<T>(), predicate)
}


//filterTo()函数将该Collections对象遍历,对其中每一个元素进行判断,如果符合一开始声明的predicate,那就可以将其加入返回对象中并在最后返回
public inline fun <T, C : MutableCollection<in T>> Iterable<T>.filterTo(destination: C, predicate: (T) -> Boolean): C {
    for (element in this) if (predicate(element)) destination.add(element)
    return destination
}

所以可以拿到我们想要的:该集合中的奇数集合

Composition of functions

/**
 * The composition function return a composition of two functions passed to it:
 * compose(f, g) = f(g(*)).
 * Now, you can apply it to callable references.
 */

fun main(args: Array<String>) {
    val oddLength = compose(::isOdd, ::length)
    val strings = listOf("a", "ab", "abc")
    println(strings.filter(oddLength))
}

fun isOdd(x: Int) = x % 2 != 0
fun length(s: String) = s.length

fun <A, B, C> compose(f: (B) -> C, g: (A) -> B): (A) -> C {
    return { x -> f(g(x)) }
}

哇这个讲组合函数(?应该可以这样翻译?)的例子也是十分抽象.

首先:compose()这个函数需要两个参数,这两个参数都是函数:

第一个函数需要传一个泛型B的实例进来,返回对象是泛型A;

第二个函数需要传递一个泛型为A的实例进来,返回对象是泛型B;

然后这个compose()函数做的事情是将泛型为A的实例对象变成C为止,然后这又是怎么做到的呢?是将我们传进来的参数传到f(g(x))中,即先将传进来的参数由第二个函数操作完,再交由第一个函数操作,返回的对象就是第一个函数执行后生成的泛型为C的实例

这个例子真的很抽象,我觉得我应该短时间内用不上这个特性...

结语

trykotlin这网站上后面还有些别的东西,longExample自己看看就好,要拿出来自己梳理好像也不好说

假装入门其实已经可以结束了,真的只是假装,因为前面这些小demo太简单了,只是梳理一下最基础最基础的特性,比如我最近想干点什么事情,发现kotlin里光是继承就很多很奇怪的东西,通过java的知识没法一下子转换过去,也估计是我太菜搞不定,遇到的坑诸如:

在kotlin里继承的时候构造突然发现不知道怎么写了呀

在kotlin里继承类后想自己添加构造方法呀

在kotlin里继承的时候如果父类有泛型不知道怎么办了呀等等等等

希望大家入门后也可以多分享些自己获得的东西出来,毕竟像我这种看着google爸爸将其纳为Android可用的第一等公民后才开始接触的不占少数(我这种放github自己不说出来也没几个人找得到??)

上一篇下一篇

猜你喜欢

热点阅读