一、扩展函数
扩展函数可以方便地给现有类增加属性和方法而不改动类地代码。
二、原理
fun String.addTo(s: String): String{
return this + s
}
反编译:
@Metadata(
mv = {1, 6, 0},
k = 2,
d1 = {"\u0000\n\n\u0000\n\u0002\u0010\u000e\n\u0002\b\u0002\u001a\u0012\u0010\u0000\u001a\u00020\u0001*\u00020\u00012\u0006\u0010\u0002\u001a\u00020\u0001¨\u0006\u0003"},
d2 = {"addTo", "", "s", "app_releaseFlavorDebug"}
)
public final class TestKt {
@NotNull
public static final String addTo(@NotNull String $this$addTo, @NotNull String s) {
Intrinsics.checkNotNullParameter($this$addTo, "$this$addTo");
Intrinsics.checkNotNullParameter(s, "s");
return $this$addTo + s;
}
}
可以看出扩展函数实际上是生成了一个静态方法,并且将被扩展的类的对象传进了函数中。
由此我们可以知道:
我们在扩展函数中可以访问被扩展的类的函数与属性,但是不能访问私有的函数与属性,其访问权限与对象访问权限一致。
三、扩展属性
扩展属性提供了一种方法能通过属性语法进行访问的API来扩展。尽管它们被叫做属性,但是它们不能拥有任何状态,它不能添加额外的字段到现有的Java对象实例。
val String.lastChar: Char get() = this[length -1]
原理与扩展函数类似。
public static final char getLastChar(@NotNull String $this$lastChar) {
Intrinsics.checkNotNullParameter($this$lastChar, "$this$lastChar");
return $this$lastChar.charAt($this$lastChar.length() - 1);
}
四、伴生对象的扩展函数
class Test{
companion object{
}
}
fun Test.Companion.get() {
}
五、总结
1、我们在扩展函数中可以访问被扩展的类的函数与属性,但是不能访问私有的函数与属性,其访问权限与对象访问权限一致。
2、扩展函数不能被子类重写。
3、扩展函数实际是一个静态函数处于类的外部,而成员函数是类的内部函数。
4、编译器会对被扩展类的调用转换为对生成的静态方法的调用。
1.本站内容仅供参考,不作为任何法律依据。用户在使用本站内容时,应自行判断其真实性、准确性和完整性,并承担相应风险。
2.本站部分内容来源于互联网,仅用于交流学习研究知识,若侵犯了您的合法权益,请及时邮件或站内私信与本站联系,我们将尽快予以处理。
3.本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
4.根据《计算机软件保护条例》第十七条规定“为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。”您需知晓本站所有内容资源均来源于网络,仅供用户交流学习与研究使用,版权归属原版权方所有,版权争议与本站无关,用户本人下载后不能用作商业或非法用途,需在24个小时之内从您的电脑中彻底删除上述内容,否则后果均由用户承担责任;如果您访问和下载此文件,表示您同意只将此文件用于参考、学习而非其他用途,否则一切后果请您自行承担,如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
5.本站是非经营性个人站点,所有软件信息均来自网络,所有资源仅供学习参考研究目的,并不贩卖软件,不存在任何商业目的及用途
暂无评论内容