博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
kotlin-inline函数
阅读量:5795 次
发布时间:2019-06-18

本文共 1243 字,大约阅读时间需要 4 分钟。

高阶函数是将函数用作参数或返回值的函数。如lambda表达式

1.高阶函数缺点: 使用高阶函数会带来一些运行时的效率损失:每一个函数都是一个对象,并且会捕获一个闭包。 即那些在函数体内会访问到的变量。 内存分配(对于函数对象和类)和虚拟调用会引入运行时间开销。

尤其在循环中,能节省很多开销。

于是,inline诞生:

lock(l) { foo() }复制代码

注:上面的代码,编译器会自动转成,不会生成函数对象

l.lock()try {    foo()}finally {    l.unlock()}复制代码

具体做法:

inline fun 
lock(lock: Lock, body: () -> T): T { …… }复制代码

2.优雅的参数类型写法

如:有时候我们需要访问一个作为参数传给我们的一个类型:

fun TreeNode.findParentOfType(clazz: Class): T? { var p = parent while (p != null && !clazz.isInstance(p)) { p = p.parent } @Suppress("UNCHECKED_CAST") return p as T? } 在这里我们向上遍历一棵树并且检查每个节点是不是特定的类型。 这都没有问题,但是调用处不是很优雅:

treeNode.findParentOfType(MyTreeNode::class.java) 我们真正想要的只是传一个类型给该函数,即像这样调用它:

treeNode.findParentOfType() 为能够这么做,内联函数支持具体化的类型参数,于是我们可以这样写:

inline fun TreeNode.findParentOfType(): T? { var p = parent while (p != null && p !is T) { p = p.parent } return p as T? } 我们使用 reified 修饰符来限定类型参数,现在可以在函数内部访问它了, 几乎就像是一个普通的类一样。由于函数是内联的,不需要反射,正常的操作符如 !is 和 as 现在都能用了。此外,我们还可以按照上面提到的方式调用它:myTree.findParentOfType()。

3.内联属性

val foo: Foo    inline get() = Foo()​var bar: Bar    get() = ……    inline set(v) { …… }你也可以标注整个属性,将它的两个访问器都标记为内联:inline var bar: Bar    get() = ……    set(v) { …… }在调用处,内联访问器如同内联函数一样内联复制代码

转载于:https://juejin.im/post/5cadacc96fb9a068b2296827

你可能感兴趣的文章
Android--从系统Camera和Gallery获取图片优化
查看>>
数据库cursor泄露的bug修改
查看>>
Python中列表append()、extend()、"+"、"+="的区别
查看>>
WIN10-解决应用程序特定权限设置并未向在应用程序容器(解决浏览器崩溃问题)...
查看>>
btrace
查看>>
【奖】51CTO学院软考班发奖学金啦(中高项、监理、信息安全)
查看>>
美国卫星撞月球 测试是否有水耗资7000多万美元
查看>>
hdfs笔记
查看>>
Callback函数
查看>>
hibernate批量插入数据库操作案例
查看>>
虚拟机新增加硬盘,不用重启读到新加的硬盘
查看>>
Java IO流详尽解析
查看>>
邮件服务系列之四基于虚拟用户的虚拟域的邮件系统(安装courier-authlib以及部分配置方法)...
查看>>
初级linux菜鸟玩转app开发
查看>>
MySQL导入数据提示max_allowed_packet错误的解决方法
查看>>
SC2012 Orchestrator - Standard Activities and Integration Pack
查看>>
另一种方法来隐藏或伪装Tomcat的版本信息
查看>>
linux7的网卡高可用 team
查看>>
Linux VSFTP服务器
查看>>
JVM类加载机制详解(一)JVM类加载过程
查看>>