我们先看看简单的函数
// 前面的文章我们了解到它是入口函数
fun main() {
}
// 对应的Java 语言,熟悉的Java 的朋友会发现,哈哈,这就是一个Java静态方法
// 我们通过两种语言的对比,能够对函数有一个更好的理解
public static final void main() {
}
// 如果没有 Java 基础,不适合看本篇文章,本篇文章针对有Java基础并想深入学习Kotlin 的小伙伴
我们写一个求和函数
fun sum(a: Int, b: Int): Int {
return a + b
}
sum函数有几部分构成呢?两部分,函数头和函数体。
函数头
-
fun
函数定义关键字 -
sum
函数名 -
(a: Int, b: Int)
函数参数 -
: Int
函数返回类型
函数体
左大括号开始,右大括号结束,中间是语句
// 我们只写了一行执行语句
return a + b
调用函数非常简单
fun main() {
val sum = sum(10, 20)
println(sum)
}
调用sum函数,传递两个Int 类型参数。返回值也是Int类型。返回结果 30
我们来看看反编译后的 Java源代码
public static final int sum(int a, int b) {
return a + b;
}
反编译Java源代码步骤,打开Intellij IDEA,按下Shift 键两次,输入show kotlin
接下来我们来看看匿名函数
定义函数时没有写名字,称为匿名函数。比如下面这个函数就是匿名函数
val f0: () -> String = {
val currentYear = 2021
"Welcome to $currentYear"
}
这个函数来一起猜猜有几部分组成!!!哈哈,你答对的概率大概三分之一。
函数类型 () -> String
函数体又称为lambda表达式 { val currentYear = 2021 "Welcome to $currentYear" }
对,它还称为匿名函数定义。最后 val f0
是函数定义的引用。
我们反编译后,查看对应的Java 代码
public final class AnonymousFunKt {
@NotNull
private static final Function0 f0;
@NotNull
public static final Function0 getF0() {
return f0;
}
public static final void main() {
Object var0 = f0.invoke();
boolean var1 = false;
System.out.println(var0);
}
// $FF: synthetic method
public static void main(String[] var0) {
main();
}
static {
f0 = (Function0)null.INSTANCE;
}
}
我们注意到函数的实例话没有写,有可能是Kotlin不想让我们知道函数的实例化。
Function0 代表没有参数,f0调用invoke方法,返回结果后,打印出结果。
这是接口的声明
public interface Function0<out R> : Function<R> {
/** Invokes the function. */
public operator fun invoke(): R
}
网友评论