/**
* 1.这里使用了可空类型?,?可以加载任何类型那个的后面来表示这个类型的变 量可以为null;
2.可空类型的变量在使用的时候不能直接调用它的方法,也不能把可空类型的值传给非空类型
*/
fun strLen(s:String?): Int = s.length //不能直接调用length方法
val x:String? = null
var y:String = x
上面x为可用类型的,y为非可空类型,现在把可空类型的x赋值给非可空类型的y会报错:Type mismatch;
同样也不能把一个可空类型的值传给拥有非可空类型参数的函数如:strLen(x)传递给strLen(x:String)
?.安全调用运算符
fun strLen(s:String?): Int = s.length //不能直接调用length方法
//如果增加了null检查之后,就可以直接调用s.length了
fun strLen(s:String?):Int = if(s!= null) s.length else 0
//但是如果每个可空类型都这样检查显得特别累赘,此时就用到了安全调用运算符?.
s?.length 就相当于 if(s != null) s.length else null
//如果s不为null就执行方法,如果为空就返回null
?: Elvis运算符(null 合并运算符)
使用?:运算符可以检查当检查结果为空的时候的返回值
fun foo(s:String?){
val t:String = s?: "" //如果?:左边的值不为空则返回左边的值,如果为空返回null
}
a?.person?.name?:"UNKNOWN" //如果?:左边为空则返回“UNKNOWN”
//和throw运算符同时使用
//如果不为空就返回name,如果为空就抛出一个有意义的错误,而不是NullPointException
a?.person?.name?:thow illegalargumentexception("Unknown name")
注意:“”不属于null的实例如:""?:"UNKNOWN" //结果为""
as? 安全转换运算符
尝试把值转换成给定的类型,如果类型不适合返回null
foo as? Type -> foo is Type return (foo as Type)
-> foo !is Type return null
as?和?:联合使用
object as? Person ?: "not human"
object as? Person ?: return false
!!非空断言(Kotlin不推荐使用非空断言,通常我们会用?:来防止程序运行时报空指针异常)
如果值为null就抛出NullPointerException空指针异常
var s:String = s!! //如果s为null则会抛出空指针异常,并且异常会指向使用!!的这一行
//但是千万不要连续使用断言!!
student!!.person!!.name //如果报空指针异常了则无法判断到底是student为空还是person为空,所以不要连续使用断言!!
let函数和?.同时使用来处理可空表达式
let函数只有左侧表达式不为空的时候才会调用
person?.let{//内部it一定是非空的
//如果person为空就不会调用let函数
}
run函数(函数内使用this代替本对象)
返回值为函数最后一行或者return指定的表达式
class TestBean{
var name: String = "Any"
var age: Int = 18
var sex: String = "girl"
fun setData(name:String ="丽丽" ,age:Int =18,sex:String = "boy"){
}
}
var result = testBean.run{
Log.i("CB","run 函数 this = "+this)//this代表当前的testBean
this?.age = 17
this?.age
//this?.name
}
Log.i("CB","run 的返回值= $result")
//返回结果为:
run 函数 this = TestBean@2ff4acd0
run 的返回值 = 18
//run 的返回值 = lily