使用Java时,我们需要大量的判断一个变量是否为null,否则使用是会抛出NullPointer异常。
而kotlin使用null给一个变量赋值时,在编译时,就会报错,来防止发生这种异常
kotlin中,除非另有规定,否则变量禁止为null
由1.可空性可知kotlin不允许给非空变量赋值null,除非我们定义变量时使用关键字"?",来表示它可能为null
fun main() {
//定义是使用?,表示它可能为空
var a: String? = "null"
a = null
println(a)
}
对于一个可空变量,调用它的函数,编译时会报错,除非你主动接受安全管理
报错:
使用非空断言操作符接收安全管理:两个"!":
fun main() {
//定义是使用?,表示它可能为空
var a: String? = "null"
a = null
//使用两个!
a = a!!.capitalize()
println(a)
}
运行时,当然抛出了异常:
Exception in thread "main" kotlin.KotlinNullPointerException
at com.aruba.mykotlinapplication.NullTestKt.main(nullTest.kt:12)
at com.aruba.mykotlinapplication.NullTestKt.main(nullTest.kt)
对于两个"!"的方式,我们程序还是抛出异常了,kotlin还提供了安全操作符"?",来自动判断变量是否为空,如果为空就不往下执行了,这在Java中必须自己判断是否为空,节省了很多代码
fun main() {
//定义是使用?,表示它可能为空
var a: String? = "null"
a = null
//使用?
a = a?.capitalize()
println(a)
}
运行程序并有没抛异常
当然也可以和Java一样,对它进行判空
fun main() {
//定义是使用?,表示它可能为空
var a: String? = "null"
a = null
if(a != null){
a = a.capitalize()
}
println(a)
}
如果变量不为空时,我们还想要执行一些其他事情,可以使用let函数
fun main() {
//定义是使用?,表示它可能为空
var a: String? = "null"
//使用?
a = a?.let {
//it就是a本身
if (it != "null")
it.capitalize()
else
"hello"
}
println(a)
}
结果:
hello
空合并操作符就是简化的三目运算符,如果:号左边是空,则执行后面的
fun main() {
//定义是使用?,表示它可能为空
var a: String? = "null"
a = null
//使用?:空合并操作符
a = a ?: "hello"
println(a)
}
结果:
hello
也可以和let配合使用
fun main() {
//定义是使用?,表示它可能为空
var a: String? = "null"
//使用?:空合并操作符
a = a?.let { it.capitalize() } ?: "hello"
println(a)
}
结果:
Null
异常大部分和Java相同,使用try catch捕获处理异常:
fun main() {
//定义是使用?,表示它可能为空
var a: String? = "null"
a = null
try {
a = a!!.capitalize()
} catch (e: Exception) {
println(e)
}
println(a)
}
自定义异常:
class MyException : RuntimeException("is null")
抛出异常:
throw MyException()
为了便利,kotlin提供了一些先决条件函数,当满足条件时,抛出异常: