四、Kotlin 表达式
1. 常量 & 变量
1.1 可读写变量(var
)
var x = initValue // x 称为可读写变量
注意:当 var
声明的变量做成员属性时,默认提供 setter
/getter
方法。
1.2 只读变量(val
)
val x = initValue // x 称为只读变量
注意:
- 当
val
声明的变量做成员属性时,默认只提供getter
方法。 - 当
val
声明的变量做全局变量或局部变量时,相当于Java
中被final
修饰的常量。
1.3 常量(const val
)
const val x = initValue // x 称为常量
注意:
const
修饰的常量只能定义在全局范围内。const
只能修饰基本类型的变量。const
修饰的变量的初始值只能是字面量。
1.4 常量引用
常量引用即:使用 val
声明的类类型的变量。
val p = Person("xiaoming")
其中:
Person
对象创建在堆区,变量p
被val
修饰,是一个常用引用。- 由于
p
是常用引用,所以不能修改p
的指向,但可以修改p
对象中的成员。
2. if-else
表达式
Java
中 if-else
只是一个语句,对应一个三目运算符 “?:
” 构成的条件表达式 express ? statement1 : statement2
Kotlin
中 if-else
即是一个语句,又可以作为一个表达式使用。
所以
Kotlin
中没有三目运算符 “?:
” 构成的条件表达式express? statement1: statement2
// if-else 语句
if(express) {statement1
} else {statement2
}// if-else 表达式
val x = if (express) statement1 else statement2 // if-else 表达式可以返回结果值
3. when
表达式
Kotlin
中的 when
表达式跟 while
循环语句没有任何关系。
3.1 Kotlin
中的 when
表达式相当于 Java
中的 switch
语句
Java
中:
swtich(a) {case 0:c = 5break;case 1:c = 100break;default:c = 20;
}
Kotlin
中:
when(a) {0 -> c = 51 -> c = 100else -> c = 20
}
其中:
1. value -> 相当于 Java 中的 case value:
2. else -> 相当于 Java 中的 default:
3. 省略了 break 语句
由于 when(condition){...}
是一个表达式,而表达式总会有结果值,所以还可以写成:
// "->" 后面的就是when表达式的结果值
c = when(a) {0 -> 51 -> 100else -> 20
}
3.2 when
表达式的条件可以放到代码块的分支中
when {// 条件表达式 x is String 保证了 x 是不可空类型 String,所以 Kotlin 会把变量 x 智能转换为不可空类型 Stringx is String -> c = x.length x == 1 -> c = 100else -> c = 20
}
同样地,由于 when
是一个表达式,会返回结果值,所以还可以写成:
c = when {x is String -> x.lengthx == 1 -> 100else -> 20
}
3.3 when
表达式的条件可以是一条赋值语句
c = when(val input = readLine()) { //变量 input 作为条件变量null -> 0 // input 为空时,when 表达式返回0else -> input.length // input 不为空时,when 表达式返回 input.length
}
4. try-catch
表达式
Kotlin
中的 try-catch
既可以作为语句,也可以作为表达式:
-
作为
try-catch
语句时,用法基本同Java
一样:try {c = a/b } catch (e: Exception) { // Kotlin中的参数声明一般是 "参数名: 参数类型", Java中则是 "参数类型 参数名"e.printStackTrace()c = 0 }
-
作为
try-catch
表达式时,最后一条执行语句的结果作为返回结果值:c = try {a/b } catch (e: Exception) {e.printStackTrace()0 }
5. 运算符重载
Kotlin
官方文档:https://kotlinlang.org/docs/operator-overloading.html
可重载的运算符仅限
Kotlin
官方文档中指定的运算符。
5.1 运算符重载函数定义
-
运算符重载函数定义时需要加关键字
operator
-
运算符重载函数可以是:全局函数、或成员方法、或扩展方法
-
子类重写父类的运算符重载函数时,可以省略关键字
operator
5.2 运算符和运算符重载函数的对应关系
-
==
对应equals
"str1" == "str2" <==> "str1".equals("str2")
-
+
对应plus
a + b <==> a.plus(b)
-
in
对应contains
element in list <==> list.contains(element)
-
[]
对应get
val value = map[key] <==> val value = map.get(key)
-
[]
对应set
map[key] = value <==> map.set(key, value)
-
>
对应compareTo
a > b <==> a.compareTo(b) > 0 // <, >=, <= 与之类似
-
()
对应invoke
// func 为匿名函数 val func = fun(p1: T1, p2: T2, ...): ReturnType {...} func(p1, p2, ...) <==> func.invoke(p1, p2, ...)
5.3 示例
6. 函数体只有一条表达式时的简写形式
当函数的函数体中仅有一条表达式语句时,可以简写成:
fun funName(p1: T1, p2: T2, ...): ReturnType = expresssion
7. 中缀表达式
中缀表达式对应一个被关键字 infix
修饰的函数。
关键字
infix
修饰的函数只能是成员方法或扩展方法。
示例 1
:
/* 函数定义 */ // 函数体只有一个表达式 "Pair(this, that)", 所以可以写成简化形式
public infix fun <A, B> A.to(that: B): Pair<A, B> = Pair(this, that) /* 函数调用 */ // 其中,简化形式 2 to 3 称为中缀表达式
2 to 3 <==> 2.to(3)
示例 2
:
/* 函数定义 */
infix fun String.minus(len: Int): String = this.substring(len until length)/* 函数调用 */ // 其中简化形式 "HelloKoltin" minus 5 称为中缀表达式
val str = "HelloKotlin" minus 5 <==> val str = "HelloKotlin".minus(5)
8. 匿名函数
对于普通函数:
// 其中 funName 称为函数名
fun funName(p1: T1, p2: T2, ...): ReturnType {...}
对应的匿名函数为:
// 其中 funRef 是函数类型为 (T1, T2, ...) -> ReturnType 的变量,接收一个匿名函数的函数引用
val funRef = fun()(p1: T1, p2: T2, ...): ReturnType {...}
9. Lambda
表达式
9.1 Java
中的 Lambda
表达式
9.1.1 什么是函数式接口
只有一个抽象方法的接口称为函数式接口,如 Runnable
接口(只有一个抽象方法 run
)。
9.1.2 Java
中的 Lambda
表达式与函数式接口的关系
Java
中的Lambda
表达式就是用来代替用于创建函数式接口对象的匿名内部类Java
中的Lambda
表达式其实就是函数式接口的抽象方法的匿名函数实现Java
中的Lambda
表达式的结果值就是一个函数式接口的实例对象
总的来说:Java
中的 Lambda
表达式其实就是一个匿名函数,这个匿名函数就是函数式接口的抽象方法。也就是说,Java
中的 Lambda
表达式就是在重写函数式接口的抽象方法。但是整个 Lambda
表达式的结果值,并不是函数式接口的抽象方法返回值,而是一个函数式接口的实例对象。
9.1.3 Java
中的 Lambda
表达式的使用场景
-
将
Lambda
表达式赋给函数式接口类型的变量; -
将
Lambda
表达式作为函数式接口类型参数的实参; -
将
Lambda
表达式强制转换为函数式接口类型。
9.1.4 Java
中的 Lambda
表达式的语法
(T1 p1, T2 p2, ...) -> {...} // 不需要显示指定返回值类型
特别地:
-
考虑到
Lambda
表达式的使用场景,总能确定Lambda
表达式对应的函数式接口,所以可以省略Lambda
表达式的形参列表中的参数类型,即:(T1 p1, T2 p2, ...) -> {...} <==> (p1, p2, ...) -> {...}
-
当形参列表只有一个参数时,可以省略括号 “
()
”,即:p1 -> {...}
-
当形参列表没有参数时,不可以省略括号 “
()
”,即:() -> {...}
-
当
Lambda
表达式中的函数体只有一条语句时,可以省略花括号 “{}
”,即:(T1 p1, T2 p2, ...) -> statement
9.2 Kotlin
中的 Lambda
表达式
9.2.1 语法
{p1: T1, p2: T2, ... -> statement1statement2...statementN
}
注意:
-
以上
Lambda
表达式对应一个函数类型为(T1, T2, ...) -> ReturnType
的匿名函数。其中ReturnType
由最后一条执行语句statementN
的结果值确定。若statementN
没有结果值,则ReturnType
为Unit
。 -
Kotlin
的Lambda
表达式的结果值是一个函数引用,所以可以将Lambda
表达式赋给函数类型为(T1, T2, ...) -> ReturnType
的变量。 -
当显示指定了变量的函数类型时,
Lambda
表达式的形参列表中的参数类型可以省略,如:val funRef: (T1, T2, ...) -> ReturnType = {p1, p2, ... ->statement1statement2...statementN // 最后一条语句的结果值必须是ReturnType }
-
当形参列表为空时,可以省略 “
p1: T1, p2: T2, ... ->
”,如:val funRef: () -> ReturnType = {statement1statement2...statementN }
-
当形参列表只有一个参数时,可以使用默认参数
it
:val funRef: (T1) -> ReturnType = {// 虽然没有声明形参列表,但存在一个 T1 类型的默认参数 it }
-
当存在一个函数,且函数形参列表的最后一个形参是函数类型,若调用该函数时,使用
Lambda
表达式作为最后一个函数类型形参的实参,则Lambda
表达式可以写在函数调用运算符 “()
” 的后面。特别地,当函数的形参列表只是一个函数类型的参数时,还可以省略函数调用运算符 “
()
”
9.2.2 Kotlin
中的 Lambda
表达式 & Java
中的 Lambda
表达式的区别
Java
中的 Lambda
表达式的结果值是一个函数式接口的实例对象。
Kotlin
中的 Lambda
表达式的结果值是一个匿名函数的函数引用。
Java
的 Lambda
表达式:
Runnable runable = () -> {// Java 的 Lambda表达式就是在重写 Runnable 接口的 run 方法...
}
Kotlin
的 Lambda
表达式:
val funRef = {// Kotlin 的 Lambda 表达式就是一个匿名函数...
}
相关文章:

四、Kotlin 表达式
1. 常量 & 变量 1.1 可读写变量(var) var x initValue // x 称为可读写变量注意:当 var 声明的变量做成员属性时,默认提供 setter/getter 方法。 1.2 只读变量(val) val x initValue // x 称为只…...

Web开发4:单元测试
在Web开发中,单元测试是一种重要的开发实践,它可以帮助我们确保代码的质量和可靠性。通过编写和运行单元测试,我们可以验证代码的正确性,减少错误和缺陷,并提高代码的可维护性。本文将介绍单元测试的概念、好处以及如何…...
Ubuntu 16 让ufw防火墙控制docker容器中所有端口
使用docker ps 查询docker在运行端口。 rootai-0003:~# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS …...

<蓝桥杯软件赛>零基础备赛20周--第18周--动态规划初步
报名明年4月蓝桥杯软件赛的同学们,如果你是大一零基础,目前懵懂中,不知该怎么办,可以看看本博客系列:备赛20周合集 20周的完整安排请点击:20周计划 每周发1个博客,共20周。 在QQ群上交流答疑&am…...
vb如何获取鼠标形状的特征码
vb如何获取鼠标形状的特征码 好像按键精灵有一个GetCursorShape()函数可以获取特征码,不知道VB6能不能实现类似的功能? 附注: 1 最好是机器无关的,不是也可以。 2 特征码就是一串数字,用来区分不同的鼠标形状。 3 获取…...

chroot: failed to run command ‘/bin/bash’: No such file or directory
1. 问题描述及原因分析 在busybox的环境下,执行 cd rootfs chroot .报错如下: chroot: failed to run command ‘/bin/bash’: No such file or directory根据报错应该rootfs文件系统中缺少/bin/bash,进入查看确实默认是sh,换成…...

蓝桥杯备战——2.矩阵键盘
1.分析原理图 由上图可以看到若J5跳线帽接地,就S4~S7就可以当做四路独立按键,若接到P44,则就是4*4的矩阵键盘。 2.独立按键处理 相对传统的按键延时消抖方案,这里我采用更高效,更经典,更偏向产品级应用的…...

Docker部署思维导图工具SimpleMindMap并实现公网远程访问
文章目录 1. Docker一键部署思维导图2. 本地访问测试3. Linux安装Cpolar4. 配置公网地址5. 远程访问思维导图6. 固定Cpolar公网地址7. 固定地址访问 SimpleMindMap 是一个可私有部署的web思维导图工具。它提供了丰富的功能和特性,包含插件化架构、多种结构类型&…...

机器学习实验2——线性回归求解加州房价问题
文章目录 🧡🧡实验内容🧡🧡🧡🧡数据预处理🧡🧡代码缺失值处理特征探索相关性分析文本数据标签编码数值型数据标准化划分数据集 🧡🧡线性回归🧡&am…...

宝塔+nextcloud+docker+Onlyoffice 全开启https
折腾了我三天的经验分享 1.宝塔创建网站 nextcloud版本为28.0.1 php8.2 ,导入nextcloud绑定域名对应的证书 ,不用创建mysql 因为nextcloud 要求是mariadb:10.7 宝塔里没有,就用docker安装一个 端口设置为3307 将数据库文件映射出来/ww…...
呼吸机电机控制主控MCU方案
呼吸机是一种能代替、控制或改变人的正常生理呼吸,增加肺通气量,改善呼吸功能,减轻呼吸功消耗,节约心脏储备能力的装置。呼吸机连接一条管子到患者的嘴或鼻子,氧气量可以通过监视器加以控制。 基于灵动微控制器的呼吸…...

gitlab备份-迁移-升级方案9.2.7升级到15版本最佳实践
背景 了解官方提供的版本的升级方案 - GitLab 8: 8.11.Z 8.12.0 8.17.7 - GitLab 9: 9.0.13 9.5.10 9.2.7 - GitLab 10: 10.0.7 10.8.7 - GitLab 11: 11.0.6 11.11.8 - GitLab 12: 12.0.12 12.1.17 12.10.14 - GitLab 13: 13.0.14 13.1.11 13.8.8 13.12.15 - G…...
redis面试题合集-基础
前言 又来到每日的复习时刻,昨天我们学习了mysql相关基础知识,还有分布式数据库介绍(后续总结时再持续更新)。今日继续学习缓存杀器:redis redis基础面试题合集 什么是Redis? Redis是一个开源的、内存中…...
(Unity)C# 中的字符串格式化
前言 在软件开发中,理解和掌握字符串的格式化及调试技巧对于编写高效和可维护的代码至关重要。 字符串插值 ($ 符号) 在 C# 中,字符串插值是通过在字符串前加 $ 符号来实现的。这允许我们将变量、表达式或函数调用直接嵌入到字符串中。 string name &qu…...

【项目日记(五)】第二层: 中心缓存的具体实现(上)
💓博主CSDN主页:杭电码农-NEO💓 ⏩专栏分类:项目日记-高并发内存池⏪ 🚚代码仓库:NEO的学习日记🚚 🌹关注我🫵带你做项目 🔝🔝 开发环境: Visual Studio 2022 项目日…...

使用PSIM软件生成DSP28335流水灯程序
最近在学习DSP28335芯片,然后在使用PSIM仿真软件时发现这个仿真软件也支持28335芯片,于是就想学习下如何在PSIM软件中使用DSP28335芯片。在PSIM自带的官方示例中有使用DSP28335芯片的相关例子。 工程下载链接 https://download.csdn.net/download/qq_20…...

【iOS ARKit】人脸检测追踪基础
在计算机人工智能(Artificial Inteligence,AI)物体检测识别领域,最先研究的是人脸检测识别,目前技术发展最成熟的也是人脸检测识别。人脸检测识别已经广泛应用于安防、机场、车站、闸机、人流控制、安全支付等众多社会领域&#x…...

ES的一些名称和概念总结
概念 先看看ElasticSearch的整体架构: 一个 ES Index 在集群模式下,有多个 Node (节点)组成。每个节点就是 ES 的Instance (实例)。每个节点上会有多个 shard (分片), P1 P2 是主分片, R1 R2…...

Javaweb之SpringBootWeb案例之阿里云OSS服务集成的详细解析
2.3.3 集成 阿里云oss对象存储服务的准备工作以及入门程序我们都已经完成了,接下来我们就需要在案例当中集成oss对象存储服务,来存储和管理案例中上传的图片。 在新增员工的时候,上传员工的图像,而之所以需要上传员工的图像&…...

【GitHub项目推荐--不错的 Go 学习项目】【转载】
开源实时性能分析平台 Pyroscope 是基于 Go 的开源实时性能分析平台,在源码中添加几行代码 pyroscope 就能帮你找出源代码中的性能问题和瓶颈、CPU 利用率过高的原因,调用树展示帮助你理解程序,支持 Go、Python、Ruby 语言。 Pyroscope 可以…...

CTF show Web 红包题第六弹
提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...

苍穹外卖--缓存菜品
1.问题说明 用户端小程序展示的菜品数据都是通过查询数据库获得,如果用户端访问量比较大,数据库访问压力随之增大 2.实现思路 通过Redis来缓存菜品数据,减少数据库查询操作。 缓存逻辑分析: ①每个分类下的菜品保持一份缓存数据…...
解决本地部署 SmolVLM2 大语言模型运行 flash-attn 报错
出现的问题 安装 flash-attn 会一直卡在 build 那一步或者运行报错 解决办法 是因为你安装的 flash-attn 版本没有对应上,所以报错,到 https://github.com/Dao-AILab/flash-attention/releases 下载对应版本,cu、torch、cp 的版本一定要对…...

OPenCV CUDA模块图像处理-----对图像执行 均值漂移滤波(Mean Shift Filtering)函数meanShiftFiltering()
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 在 GPU 上对图像执行 均值漂移滤波(Mean Shift Filtering),用于图像分割或平滑处理。 该函数将输入图像中的…...
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件,用于在原生应用中加载 HTML 页面: 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...
基于Java Swing的电子通讯录设计与实现:附系统托盘功能代码详解
JAVASQL电子通讯录带系统托盘 一、系统概述 本电子通讯录系统采用Java Swing开发桌面应用,结合SQLite数据库实现联系人管理功能,并集成系统托盘功能提升用户体验。系统支持联系人的增删改查、分组管理、搜索过滤等功能,同时可以最小化到系统…...

深入浅出深度学习基础:从感知机到全连接神经网络的核心原理与应用
文章目录 前言一、感知机 (Perceptron)1.1 基础介绍1.1.1 感知机是什么?1.1.2 感知机的工作原理 1.2 感知机的简单应用:基本逻辑门1.2.1 逻辑与 (Logic AND)1.2.2 逻辑或 (Logic OR)1.2.3 逻辑与非 (Logic NAND) 1.3 感知机的实现1.3.1 简单实现 (基于阈…...

MySQL 知识小结(一)
一、my.cnf配置详解 我们知道安装MySQL有两种方式来安装咱们的MySQL数据库,分别是二进制安装编译数据库或者使用三方yum来进行安装,第三方yum的安装相对于二进制压缩包的安装更快捷,但是文件存放起来数据比较冗余,用二进制能够更好管理咱们M…...

【从零开始学习JVM | 第四篇】类加载器和双亲委派机制(高频面试题)
前言: 双亲委派机制对于面试这块来说非常重要,在实际开发中也是经常遇见需要打破双亲委派的需求,今天我们一起来探索一下什么是双亲委派机制,在此之前我们先介绍一下类的加载器。 目录 编辑 前言: 类加载器 1. …...

手机平板能效生态设计指令EU 2023/1670标准解读
手机平板能效生态设计指令EU 2023/1670标准解读 以下是针对欧盟《手机和平板电脑生态设计法规》(EU) 2023/1670 的核心解读,综合法规核心要求、最新修正及企业合规要点: 一、法规背景与目标 生效与强制时间 发布于2023年8月31日(OJ公报&…...