在Kotlin中,@JvmOverloads注解的作用是:在有默认参数值的方法中使用@JvmOverloads注解,则kotlin会暴露多个重载方法。
例子:
@JvmOverloads
fun test( name: String, age : Int, sex : Int = 1, num : Int = 10) {
Log.i("TAG", "test: ab = " + name)
}
//调用
test("a", 2)
test("a", 2, 2)
test("a", 2, num = 2)
test("a", 2, 2, 10)
我们将其转为java代码看看
@JvmOverloads
public final void test(@NotNull String name, int age, int sex, int num) {
Intrinsics.checkNotNullParameter(name, "name");
Log.i("TAG", "test: ab = " + name);
}
// $FF: synthetic method
public static void test$default(MainActivity var0, String var1, int var2, int var3, int var4, int var5, Object var6) {
if ((var5 & 4) != 0) {
var3 = 1;
}
if ((var5 & 8) != 0) {
var4 = 10;
}
var0.test(var1, var2, var3, var4);
}
@JvmOverloads
public final void test(@NotNull String name, int age, int sex) {
test$default(this, name, age, sex, 0, 8, (Object)null);
}
@JvmOverloads
public final void test(@NotNull String name, int age) {
test$default(this, name, age, 0, 0, 12, (Object)null);
}
//调用
test$default(this, "a", 2, 0, 0, 12, (Object)null);
test$default(this, "a", 2, 2, 0, 8, (Object)null);
test$default(this, "a", 2, 0, 2, 4, (Object)null);
this.test("a", 2, 2, 10);
可以看到重载了同名不同参数的方法,但是可以看到,重载的方法里面多了一些数字参数4、8、12。
这里是一个非常巧的操作,以这个函数为例,有4个参数,也就是4个位置,每个位置分别有一个mask值,为2的n-1次方(n就是位置的顺序),所以这四个位置代表的mask值分别为1,2,4,8。如果当前位置没有参数调用,那么就将其mask值累加,最后得到一个结果。
最后将该结果分别与对应的mask值进行与运算,就可以得知该位置有没有参数调用,如果没有,就对该参数赋予默认值,这就实现了参数默认值的效果。