Kotlin非常用关键字使用记录

1,typealias 声明一个类型别名。

样例:

复制代码
typealias MyBean=ItemBean
复制代码
data class ItemBean(val title: String, val intent: Intent)
复制代码
val bean=MyBean("11", Intent())

实现了将ItemBean数据模型取了一个别名MyBean,后续我们可以像使用别名一样使用他们

2,crossinline 禁止传递给内联函数的 lambda 中的非局部返回。

样例:

复制代码
private inline fun textCrossInline(crossinline value:()->Unit){
    value()
}

override fun afterInitView() {
    super.afterInitView()
    textCrossInline { 
        return//直接报错,说不能这么返回
    }
}

如果改成下面这样就可以

private inline fun textCrossInline(value:()->Unit){ value() }

3,expect 将一个声明标记为平台相关,并期待在平台模块中实现。

用于实现声明函数或者接口或者抽象类,但是具体实现在具体对应的平台上面

4,infix 允许用中缀表示法调用函数,使函数的调用方式更加简介和个性化

样例:

复制代码
infix fun String.plusjdz(value:String):String{
    return (this.hashCode()+value.hashCode()).toString()
}
复制代码
println("a" plusjdz "b")

5,internal 将一个声明标记为在当前模块中可见。

6,noinline 关闭传给内联函数的 lambda 表达式的内联。

和inline关键字不同之处在于,noinline是给lambda表达式的参数标记 的,inline标记函数,编译器会默认把所有lambda参数都到对应位置展开 ,而有的lambda参数不想内联怎么办?
被noinline标记的参数会默认不内联,也就是说把完整的函数调用保留下来;

7,tailrec 将一个函数标记为尾递归(允许编译器将递归替换为迭代)。

它是通过编译器对递归调用做了优化,减少了出现栈溢出风险

复制代码
tailrec fun sums(a:Int,initValue:Int):Int{
    if (a==0)return initValue
    return sums(a-1,initValue+a)
}

反编译优化后的字节码:

复制代码
public final int sums(int a, int initValue) {
   while(a != 0) {
      int var10000 = a - 1;
      initValue += a;
      a = var10000;
   }

   return initValue;
}
相关推荐
421!2 分钟前
GPIO工作原理以及核心
开发语言·单片机·嵌入式硬件·学习
摇滚侠17 分钟前
JAVA 项目教程《苍穹外卖-12》,微信小程序项目,前后端分离,从开发到部署
java·开发语言·vue.js·node.js
@insist12338 分钟前
网络工程师-生成树协议(STP/RSTP/MSTP)核心原理与应用
服务器·开发语言·网络工程师·软考·软件水平考试
野生技术架构师1 小时前
2026年牛客网最新Java面试题总结
java·开发语言
环黄金线HHJX.1 小时前
Tuan符号系统重塑智能开发
开发语言·人工智能·算法·编辑器
dog2501 小时前
对数的大脑应对指数的世界
开发语言·php
Mr_Xuhhh1 小时前
深入理解Java抽象类与接口:从概念到实战
java·开发语言
萝卜白菜。2 小时前
TongWeb7.0相同的类指明加载顺序
开发语言·python·pycharm
wb043072012 小时前
使用 Java 开发 MCP 服务并发布到 Maven 中央仓库完整指南
java·开发语言·spring boot·ai·maven
Rsun045512 小时前
设计模式应该怎么学
java·开发语言·设计模式