我们之前学了 Kotlin 中函数式 API 的用法,但实际上 Kotlin 调用 Java 方法时也可以使用函数式 API,只不过有一定条件限制。具体来讲,如果我们在 Kotlin 代码中调用了一个 Java 方法,并且该方法接收一个 Java 单抽象方法接口参数,就可以使用函数式 API
Java 单抽象方法接口指的是接口中只有一个待实现方法。如果接口中有多个待实现方法,则无法使用函数式 API
举个栗子:Java 原生 API 中有一个最常见的单抽象方法接口 Runnable 接口,这个接口只有一个待实现的 run()
方法
根据前面的讲解,任何一个 Java 方法,只要它接收 Runnable 参数,就可以使用函数式 API。Runnable 接口主要还是结合线程一起使用,因此我们使用 Thread 类来学习下
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("Thread is Running");
}
}).start();
如果翻译成 Kotlin 版本:
Thread(object : Runnable {
override fun run() {
println("Thread is Running")
}
}).start()
Kotlin 中匿名类的写法和 Java 有点区别,由于 Kotlin 完全舍弃了 new
关键字,因此创建匿名类实例的时候就不能使用 new 了,而是改用了 object 关键字。并没什么简化之处,但是目前 Thread 类的构造方法是符合 Java 函数式 API 的使用条件的,所以我们来进行简化。因为 Runnable 类中只有一个待实现的方法,所以没有显式重写 run()
方法,Kotlin 也能自动明白 Runnable 后边的 Lambda 表达式里是要在 run()
方法中实现的内容
Thread(Runnable { println("Thread is Running") }).start()
还可简化,当 Lambda 表达式是方法最后一个参数时,可以将 Lambda 表达式移到方法括号外面。同时,如果 Lambda 表达式还是方法唯一一个参数,还可以将方法括号省略,最终简化结果如下:
Thread{ println("Thread is Running")}.start()