KClass
kt 中 Classs 類。其對(duì)應(yīng)的是
java.lang.Class。
下面所使用的 Test 類定義如下:
class Test {
var name: String = ""
fun test(sex: String, age: Int) = "$sex+$age"
}
-
通過
MyClass::class獲取指定類對(duì)應(yīng)的 KClass 對(duì)象。就像在 java 中通過MyClass.class獲取指定類的 Class 對(duì)象一樣。fun main(args: Array<String>) { val t = Test() val clazz:KClass<Test> = Test::class // 返回一個(gè) KClass 對(duì)象 } -
通過
對(duì)象.javaClass.kotlin獲取指定實(shí)例對(duì)應(yīng)的 KClass 實(shí)例。其中對(duì)象.javaClass可以獲取指定類的 java Class 實(shí)例。fun main(args: Array<String>) { val t = Test() println(t.javaClass is Class) // true } -
KClass 與 Class 轉(zhuǎn)換:
對(duì)象.javaClass得到 Class 對(duì)象,再.kotlin得到 KClass 對(duì)象類名::class得到 KClass 對(duì)象,再.java得到 Class 對(duì)象。對(duì)象::class得到 KClass 對(duì)象,再.java得到 Class 對(duì)象。
屬性
KClass 屬性如下:
| 屬性 | 含義 |
|---|---|
| memberProperties | 所有屬性,含從父類中繼承的 |
| annotations | 獲取元素上的所有注解。定義于 KAnnotatedElement 中 |
| createInstance() | 方法。通過 KClass 創(chuàng)建一個(gè)實(shí)例 |
| objectInstance | 如果類是單例的,則存儲(chǔ)其唯一實(shí)例。否則為空 |
object Test {
val name = "naan"
fun test() = println("tesss")
}
則 Test::class.objectInstance 其不為空,如果將 object 換成 class ,則值為空
KCallback 與 KFunction,KProperty
KCallback 是函數(shù)和屬性的超接口。其內(nèi)部定義有 call 方法,調(diào)用該方法就相當(dāng)于調(diào)用函數(shù)或者屬性的 getter ;KFunction 是 KCallback 的子類,它是函數(shù)的接口;KProperty 是 KCallback 的子類,它是屬性的接口。
| 屬性 | 含義 |
|---|---|
| name | 獲取方法或?qū)傩悦?/td> |
| parameters | 參數(shù)列表 |
三者接收的第一個(gè)參數(shù)均為執(zhí)行該方法所需要的對(duì)象。就像 java 中執(zhí)行某個(gè)反射方法時(shí),需要為該方法指定一個(gè)執(zhí)行對(duì)象。
KFunction 的泛型說明:除最后一個(gè)泛型外,其余的均為調(diào)用其 invoke 方法時(shí)需要傳遞參數(shù)類型,最后一個(gè)泛型為 invoke 方法返回值類型。也即對(duì)應(yīng)方法的參數(shù)類型列表和返回值類型。
使用 成員引用函數(shù)時(shí),返回的是一個(gè) KFunction 實(shí)例。調(diào)用其 invoke 就相當(dāng)于執(zhí)行該方法:

-
使用 成員引用屬性時(shí),返回的是一個(gè) KProperty 實(shí)例。調(diào)用其
get相當(dāng)于調(diào)用該實(shí)例的 getter 方法:KProperty KProperty 泛型說明:第一個(gè)參數(shù)表示接收者類型,第二個(gè)參數(shù)表示屬性類型。
對(duì)于 var 修飾的變量,通過 KProperty 定義 set 方法修改其值。但對(duì)不可變變量,沒有 set 方法。
parameters 返回的參數(shù)列表中,第一個(gè)參數(shù)為 receiver,表示執(zhí)行當(dāng)前方法的實(shí)例。
繼承關(guān)系

因?yàn)樗械穆暶鞫伎梢员蛔⒔猓↘AnnotatedElement 類的作用),所以 KClasss,KCallback,KParameter 都繼承于 KAnnotatedElement。
KProperty 只有 get 方法,用于 val 聲明的變量
KMutableProperty 有 set 方法,用于 var 聲明的變更。
兩者內(nèi)部有 getter/setter 接口,用于獲取相應(yīng)屬性的 getter/setter 方法。getter/setter 接口都繼承于 KFunction,因此可以把他們當(dāng)作函數(shù)調(diào)用。
fun main(args: Array<String>) {
val test = Test::name
val t = Test()
println(test.getter.invoke(t))
test.setter.invoke(t,"yyy")
println(test.getter.invoke(t))
}
構(gòu)造函數(shù)
通過
KClass#constructors可以獲取所有的構(gòu)造函數(shù)。
構(gòu)造函數(shù)也是函數(shù),因此每一個(gè)構(gòu)造函數(shù)都是 KFunction 的子類。故而可以調(diào)用 call 方法創(chuàng)建實(shí)例
fun main(args: Array<String>) {
val kclzzz = Test::class
val t = kclzzz.constructors
t.forEach {
val i = it.call("name", 20)
println(i)
}
}
data class Test(val name: String, var age: Int = 10)
但 call 方法不支持默認(rèn)參數(shù),即上面創(chuàng)建實(shí)例時(shí),即使 Test 類中 age 已經(jīng)指定了默認(rèn)值 10 ,調(diào)用 call() 時(shí)也必須傳入一個(gè)對(duì)應(yīng)的實(shí)參。
callBy
callBy 定義在 KCallback 類中。
與 call() 方法相比,它接收一個(gè) map —— map 存儲(chǔ)了方法形參與其實(shí)參之間的對(duì)應(yīng)關(guān)系。
- 如果 map 缺少形參,則該形參會(huì)使用默認(rèn)值,如果有默認(rèn)值的話
2.形參的順序不必和方法中一樣
- map 中值的類型需要跟構(gòu)造方法中參數(shù)類型一致。
KParameter
方法參數(shù)
name 表示參數(shù)名
type 表示參數(shù)類型
isOptional 表示該參數(shù)是否有默認(rèn)值。true 表示有默認(rèn)值,false 沒有。
