Kotlin - 参数与异常

简介: Kotlin - 参数与异常

本系列学习教程笔记属于详细讲解Kotlin语法的教程,需要快速学习Kotlin语法的小伙伴可以查看“简洁” 系列的教程

快速入门请阅读如下简洁教程:
Kotlin学习教程(一)
Kotlin学习教程(二)
Kotlin学习教程(三)
Kotlin学习教程(四)
Kotlin学习教程(五)
Kotlin学习教程(六)
Kotlin学习教程(七)
Kotlin学习教程(八)
Kotlin学习教程(九)
Kotlin学习教程(十)

imgKotlin - 参数与异常

#具名参数

具名参数就是在调用函数时,给函数的实参附上形参:

fun sum(arg1: Int, arg2: Int) = arg1 + arg2

fun main(vararg args: String) {
    sum(arg1 = 2, arg2 = 3)
    sum(arg2 = 3, arg1 = 2)
}

使用具名参数可以把实参精确的传递给指定形参,因此具名参数可以不用按顺序传入。

#变长参数

vararg 可以让某个参数接收多个值,vararg 修饰的参数称为变长参数:

fun hello(vararg ints: Int, string: String) {
    ints.forEach(::println)
    println(string)
}

fun main(vararg args: String) {
    // hello(1, 2, 3, 4, 5, "hello") // IDE报错:Type mismatch. Required:Int Found:String
    hello(1, 2, 3, 4, 5, string = "hello")
}
  • 变长参数可以不为最后一个参数
  • 如果传参时有歧义,需要使用具名参数

#展开操作符(Spread Operator)

当变长参数需要传入一个数组时,可以使用展开操作符 ** 会将数组展开后一一传入:

val array = intArrayOf(1, 2, 3, 4, 5)
hello(*array, string = "Hello") // vararg变长参数场景下,*号可以把Array数组展开,但不支持List

展开操作符 * 有以下几个特点:

  • 只支持展开 Array
  • 只用于变长参数列表的实参
  • 不是一般意义上的操作符,不能重载

#默认参数

默认参数,即可以为函数任意位置的参数指定默认值:

fun say(age: Int = 20, name: String, height: Float) {
    ...
}

fun main(vararg args: String) {
    say(18, "lqr", 2.0f)
    say(name = "lqr", height = 2.0f)
}

如果默认参数导致传参出现歧义时,需要使用具名参数。换句话说,就是默认参数后面的参数需要使用具名参数传值。

#多返回值

借助 PairTriple 可以实现函数返回多值(注:伪多返回值),因为 PairTriple 支持 解构 语法:

fun main(vararg args: String) {
    val (myName, myAge) = multiReturnValues()
    println("myName is $myName, myAge is $myAge")

    val (name, age, height) = multiReturnValues(180.0)
    println("name is $name, age is $age, height is $height")
}

fun multiReturnValues(): Pair<String, Int> {
    // return Pair("lqr", 18)
    return "lqr" to 18
}

fun multiReturnValues(height: Double): Triple<String, Int, Double> {
    return Triple("lqr", 18, height)
}

to 是中缀表达式,返回的就是 Pair,也就是 Map 里的键值对。

#捕获异常

Kotlin 支持 try...catchtry...catch...finally 捕获异常,catch 分支匹配异常类型,finally 无论代码是否抛出异常都会执行:

try {
    val arg1 = args[0].toInt()
    val arg2 = args[1].toInt()
    println("$arg1 + $arg2 = ${sum(arg1, arg2)}")
} catch (e: NumberFormatException) {
    println("输入的数据不是数字")
} catch (e: ArrayIndexOutOfBoundsException) {
    println("需要输入2个数字")
} catch (e: Exception) {
    println("出现未知异常:${e.message}")
} finally {
    println("感谢使用")
}

跟 if、when 一样,try...catch 也可以是表达式,可以用来赋值:

val result = try {
    args[0].toInt() / args[1].toInt()
} catch (e: Exception) {
    0
}
相关文章
|
9月前
|
Python
Python f-strings:让字符串格式化更简洁高效!
Python f-strings:让字符串格式化更简洁高效!
394 81
|
12月前
|
设计模式 XML 算法
策略模式(Strategy Pattern)深度解析教程
策略模式属于行为型设计模式,通过定义算法族并将其封装为独立的策略类,使得算法可以动态切换且与使用它的客户端解耦。该模式通过组合替代继承,符合开闭原则(对扩展开放,对修改关闭)。
|
机器学习/深度学习 人工智能 供应链
AI智能分析
AI智能分析运用人工智能技术对数据进行深度挖掘和模式识别,助力商业智能、法律分析、医疗健康、股票市场、产品设计和技术研发等领域。通过机器学习和深度学习,AI能优化商业策略、提升诊断精度、辅助投资决策,并解决技术难题,为各行各业提供精准洞察和决策支持。
673 1
|
12月前
|
人工智能 API 开发者
无需邀请码!MetaGPT 开源AI助手 OpenManus,实时反馈+模块化设计,开发者福音
OpenManus 是 MetaGPT 团队推出的开源 AI Agent 复刻版,支持多种语言模型和工具链,能够执行代码、处理文件、搜索网络信息等复杂任务,具备实时反馈机制和灵活的配置选项。
765 17
无需邀请码!MetaGPT 开源AI助手 OpenManus,实时反馈+模块化设计,开发者福音
python推导式-列表,元组,字典,集合推导式
这篇文章介绍了Python中的推导式,包括列表推导式、元组推导式、字典推导式和集合推导式,提供了它们的基本格式和示例代码,并解释了推导式如何简化循环和条件判断的代码编写。
|
安全 前端开发 PHP
Upload-labs 通关解析(上)
Upload-labs 靶场通关解析(上)
|
网络性能优化 开发工具 git
使用git rebase --onto一例
使用git rebase --onto一例
|
存储 测试技术 iOS开发
CocoaLumberjack的ios应用开发使用指南
CocoaLumberjack的ios应用开发使用指南
524 2
|
算法 计算机视觉
OpenCV对图像进行Otsu二值分割、Canny边缘检测、Harris角点检测实战(附源码)
OpenCV对图像进行Otsu二值分割、Canny边缘检测、Harris角点检测实战(附源码)
375 0
|
XML Java API
Spring Boot 整合 Quartz 实现 Java 定时任务的动态配置
Spring Boot 整合 Quartz 实现 Java 定时任务的动态配置
588 0

热门文章

最新文章