本人也是在初学Kotlin,如有错误,请帮忙指出,持续更新
Android:Kotlin详细入门学习指南-函数-基础语法(六)
建议先看看前面的文章
Android:Kotlin详细入门学习指南-基础语法(一)
Android:Kotlin详细入门学习指南-基本类型-基础语法(二)
Android:Kotlin详细入门学习指南-包-控制流-返回与跳转-基础语法(三)
Android:Kotlin详细入门学习指南-类和对象-基础语法(四)
Android:Kotlin详细入门学习指南-类和对象(下)-基础语法(五)
这篇文章分享的内容比较多,建议先关注收藏,再查看,以免迷路
函数
函数声明
在 kotlin 中用关键字 fun 声明函数:
fun double(x: Int): Int { }
函数用法
通过传统的方法调用函数
val result = double(2)
通过 . 调用成员函数
Sample().foo() // 创建Sample类的实例,调用foo方法
参数
函数参数是用 Pascal 符号定义的 name:type。参数之间用逗号隔开,每个参数必 须指明类型。
fun powerOf(number: Int, exponent: Int) { ... }
默认参数
函数参数可以设置默认值,当参数被忽略时会使用默认值。这样相比其他语言可以减 少重载。
fun read(b: Array<Byte>, off: Int = 0, len: Int = b.size() ) { ... }
默认值可以通过在type类型后使用 = 号进行赋值
命名参数
fun reformat(str: String, normalizeCase: Boolean = true,
upperCas eFirstLetter: Boolean = true, divideByCamelHumps: Boolean = false,
wordSeparator: Char = ' ') { ... }
以使用默认参数
reformat(str)
然而当调用非默认参数是就需要像下面这样:
reformat(str, true, true, false, '_')
使用命名参数我们可以让代码可读性更强:
reformat(str,
normalizeCase = true,
uppercaseFirstLetter = true,
divideByCamelHumps = false,
wordSeparator = '_'
)
如果不需要全部参数的话可以这样:
reformat(str, wordSeparator = '_')
不带返回值的参数
如果函数不会返回任何有用值,那么他的返回类型就是 Unit . Unit 是一个只 有唯一值 Unit 的类型.这个值并不需要被直接返回,可以省略不写,和java的void一样
fun printHello(name: String?): Unit {}
fun printHello(name: String?) {} //省略
单表达式函数
当函数只返回单个表达式时,大括号可以省略并在 = 后面定义函数体
fun double(x: Int): Int = x*2
fun double(x: Int) = x * 2
变长参数
函数的参数(通常是最后一个参数)可以用 vararg 修饰符进行标记:
fun asList<T>(vararg ts: T): List<T> {
val result = ArrayList<T>()
for (t in ts)
result.add(t)
return result
}
val list = asList(1, 2, 3)
当调用变长参数的函数时,我们可以一个一个的传递参数,比如 asList(1, 2, 3) ,或者我们要传递一个 array 的内容给函数,我们就可以使用 * 前缀操作符:
val a = array(1, 2, 3)
val list = asList(-1, 0, *a, 4)
函数范围
Kotlin 中可以在文件顶级声明函数,这就意味者你不用像在Java,C#或是Scala一样 创建一个类来持有函数。除了顶级函数,Kotlin 函数可以声明为局部的,作为成员 函数或扩展函数。
局部函数
Kotlin 支持局部函数,比如在一个函数包含另一函数。
局部函数可以访问外部函数的局部变量(比如闭包)
局部函数甚至可以返回到外部函数
成员函数
成员函数是定义在一个类或对象里边的
class Sample() {
fun foo() {
print("Foo")
}
}
成员函数可以用 . 的方式调用 Sample.foo()
泛型函数
函数可以有泛型参数,样式是在函数后跟上尖括号。
fun sigletonArray<T>(item: T): Array<T> {
return Array<T>(1, {item})
}
尾递归函数
Kotlin 支持函数式编程的尾递归。这个允许一些算法可以通过循环而不是递归解决 问题,从而避免了栈溢出。当函数被标记为 tailrec 时,编译器会优化递归,并 用高效迅速的循环代替它。
tailrec fun findFixPoint(x: Double = 1.0): Double
= if (x == Math.cos(x)) x
else findFixPoint(Math.cos(x))
这段代码计算的是数学上的余弦不动点。Math.cos 从 1.0 开始不断重复,直到值不 变为止,结果是 0.7390851332151607 这段代码和下面的是等效的:
private fun findFixPoint(): Double {
var x = 1.0
while (true) {
val y = Math.cos(x)
if ( x == y )
return y
x = y
}
}
使用 tailrec 修饰符必须在最后一个操作中调用自己。在递归调用代码后面是不 允许有其它代码的,并且也不可以在 try/catch/finall 块中进行使用。当前的尾递归 只在 JVM 的后端中可以用.