Kotlin与Java写法的变更

目录

[获取类的Java Class属性](#获取类的Java Class属性)

类型检查

for循环

switch语句

if判断


获取类的Java Class属性

java 复制代码
//Java
Intent intent = new Intent(this, MainActivity.class);

//Kotlin
val intent = Intent(this, MainActivity::class.java)

类型检查

java 复制代码
//Java
apple instanceof Fruit
!(apple instanceof Fruit)

//Kotlin
apple is Fruit
apple !is Fruit

for循环

java 复制代码
//Java
List<String> list = new ArrayList<>();
for (int i = 0; i < list.size(); i++) {
    //do something
}

//Kotlin 一般写法
for (element in sList) {
    //do something
}

//Kotlin 不需要下标
list.forEach {
    //do something
}

//Kotlin 需要下标
list.forEachIndexed { element, index ->
    //do something
}

switch语句

java

java 复制代码
        int status = 0;
        int timeout = 0;
        switch(status){
            case STATUS_1:
                timeout = 100;
                break;
            case STATUS_2:
                timeout = 200;
                break;
            case STATUS_3:
                timeout = 300;
                break;
            default:
                timeout = 500;
                break;
        }

在Kotlin中,switch语句正式退出了历史舞台,取而代之的是更为强大的when表达式。注意语句(statement)和表达式(expression)的区别。通俗来讲,他们最大的区别是语句没有值,而表达式有值。因此在Kotlin中可以这样用:

java 复制代码
val status = 0
fun getTime(): Int = when (status) {
    1 -> 100
    2 -> 200
    3 -> 300
    else -> 500
}

if判断

在Kotlin中,if变成了表达式,等同于 Java中三目运算符的替代写法:

复制代码
fun getStatus(score:Int) = if(score >85) "优秀" else "其他"
相关推荐
无限的鲜花8 小时前
反射(原创推荐)
java·开发语言
IT二叔8 小时前
Java项目部署-03-teamcity-cicd-docker镜像流水线方式部署
java·ci/cd·持续部署
yongche_shi8 小时前
ragas官方文档中文版(五十)
开发语言·python·ai·ragas·如何评估和改进 rag 应用
一路向北he8 小时前
字节钢铁军团--“提供情境,而非控制”
java·开发语言·前端
超级数据查看器9 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
AI行业学习10 小时前
Notepad++ 官方下载 + 完整安装 + 全套优化配置(2026最新)
开发语言·人工智能·python·前端框架·html·notepad++
折哥的程序人生 · 物流技术专研10 小时前
《Java 100 天进阶之路》第50篇:阻塞队列与并发容器(2026版)
java·面试题·java进阶·blockingqueue·并发容器·集合源码·java100天进阶
ai_coder_ai10 小时前
编写自动化脚本,在自己后端服务中使用Open Api进行设备相关操作
java·运维·自动化
大圣编程10 小时前
Python中continue语句的用法是什么?
开发语言·前端·python
硕风和炜11 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集