本篇文章将介绍 Kotlin 的基本语法中函数,可见性修饰符以及顶层函数的概念,并与 Java 中的相关概念做出比较。
阅读本文大概需要 3 分钟
如何定义一个函数?首先以经典的 HelloWorld 展现,这是一个可以打印 HelloWorld 的 Kotlin 方法和一个 Java 实现版本
HelloWorld.kt
fun main(args : Array<String>){
println ("Hello, world!")
}
复制代码
HelloWorld.java
public void main(Array<String> args){
System.out.println("Hello, world!");
}
复制代码
从这个例子我们可以初步体会 Kotlin 的特点。
fun , 关键字开头,这点在 Java 中是没有的。 Kotlin 的方法参数列表中,类型与变量名以 : 作为区分,并且变量类型放在 : 后面,这很像 UML 类图中方法的写法 顶层函数 ,这个语法在 Java 中是没有的 public , 因此你可以省略它 下面将详细介绍顶层函数与 Kotlin 可见性修饰符的概念
可见性修饰符帮助控制代码库中的声明访问,总体来说,Kotlin 的访问限制符与 Java 类似,下面对 Kotlin 和 Java 可见性修饰符做了一个介绍和比对
顶层函数即不从属于任何类的函数。这些函数直接写在类的外面,代码的最顶层。处于文件顶层的函数依然是包内的成员,如果想在包外访问,使用 import 导入即可。
同顶层函数一样,顶层属性也是写在类外部的数据片段。默认情况下,顶层属性与声明在类中的属性一致,都是通过访问器暴露给 Java 使用
那么 Kotlin 为什么要设计顶层函数和顶层属性?我们知道,在 Java 中,所有的代码都写在类的内部,一般没有什么问题,但是对于大型项目,总有一些代码不能归属到同一个类中,这会使得某个类不断变得臃肿,不再满足单一职责。例如项目中的许多 Utils 结尾的类,那么有了,例如这里用 java 实现的获取无分隔符的 UUID 的函数
public static String getUUID() {
String s = UUID.randomUUID().toString(); // 默认存在 “-”
return s.substring(0, 8) + s.substring(9, 13) + s.substring(14, 18)
+ s.substring(19, 23) + s.substring(24); // 去掉“-”符号
}
复制代码
现在有了 Kotlin 中的顶层函数的语法,就可以不必创造这些毫无意义的类,不必用类将这些函数包裹起来,可以将这些零散的函数之间放在 Kotlin 文件中,通过 import 引入即可。下面是 Kotlin 声明及使用顶层函数的代码:
声明:
package util
fun getUUID(): String{
....
}
使用:
import util.getUUID // 导入顶层函数
fun main(args: Array<String>){
var id = getUUID()
}
复制代码