我們先看看簡(jiǎn)單的函數(shù)
// 前面的文章我們了解到它是入口函數(shù)
fun main() {
}
// 對(duì)應(yīng)的Java 語(yǔ)言,熟悉的Java 的朋友會(huì)發(fā)現(xiàn),哈哈,這就是一個(gè)Java靜態(tài)方法
// 我們通過(guò)兩種語(yǔ)言的對(duì)比,能夠?qū)瘮?shù)有一個(gè)更好的理解
public static final void main() {
}
// 如果沒(méi)有 Java 基礎(chǔ),不適合看本篇文章,本篇文章針對(duì)有Java基礎(chǔ)并想深入學(xué)習(xí)Kotlin 的小伙伴
我們寫(xiě)一個(gè)求和函數(shù)
fun sum(a: Int, b: Int): Int {
return a + b
}
sum函數(shù)有幾部分構(gòu)成呢??jī)刹糠?,函?shù)頭和函數(shù)體。
函數(shù)頭
-
fun函數(shù)定義關(guān)鍵字 -
sum函數(shù)名 -
(a: Int, b: Int)函數(shù)參數(shù) -
: Int函數(shù)返回類型
函數(shù)體
左大括號(hào)開(kāi)始,右大括號(hào)結(jié)束,中間是語(yǔ)句
// 我們只寫(xiě)了一行執(zhí)行語(yǔ)句
return a + b
調(diào)用函數(shù)非常簡(jiǎn)單
fun main() {
val sum = sum(10, 20)
println(sum)
}
調(diào)用sum函數(shù),傳遞兩個(gè)Int 類型參數(shù)。返回值也是Int類型。返回結(jié)果 30
我們來(lái)看看反編譯后的 Java源代碼
public static final int sum(int a, int b) {
return a + b;
}
反編譯Java源代碼步驟,打開(kāi)Intellij IDEA,按下Shift 鍵兩次,輸入show kotlin



接下來(lái)我們來(lái)看看匿名函數(shù)
定義函數(shù)時(shí)沒(méi)有寫(xiě)名字,稱為匿名函數(shù)。比如下面這個(gè)函數(shù)就是匿名函數(shù)
val f0: () -> String = {
val currentYear = 2021
"Welcome to $currentYear"
}
這個(gè)函數(shù)來(lái)一起猜猜有幾部分組成!??!哈哈,你答對(duì)的概率大概三分之一。
函數(shù)類型 () -> String
函數(shù)體又稱為lambda表達(dá)式 { val currentYear = 2021 "Welcome to $currentYear" } 對(duì),它還稱為匿名函數(shù)定義。最后 val f0 是函數(shù)定義的引用。
我們反編譯后,查看對(duì)應(yīng)的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;
}
}
我們注意到函數(shù)的實(shí)例話沒(méi)有寫(xiě),有可能是Kotlin不想讓我們知道函數(shù)的實(shí)例化。
Function0 代表沒(méi)有參數(shù),f0調(diào)用invoke方法,返回結(jié)果后,打印出結(jié)果。
這是接口的聲明
public interface Function0<out R> : Function<R> {
/** Invokes the function. */
public operator fun invoke(): R
}