Kotlin设计之初就是不允许非null变量在声明期间不进行初始化的,为了解决这个问题,Kotlin lateinit 允许我们先声明一个变量,然后在程序执行周期的将来某个时候将其初始化,让编译检
Kotlin设计之初就是不允许非null变量在声明期间不进行初始化的,为了解决这个问题,Kotlin lateinit 允许我们先声明一个变量,然后在程序执行周期的将来某个时候将其初始化,让编译检查时不会 因为属性变量未被初始化而报错。如果未初始化将导致以下异常:
kotlin.UninitializedPropertyAccessException: lateinit property mList has not been initialized
所以我们在 Kotlin 1.2及更高版本上,经常使用基于反射的API 快速检查lateinit属性是否已初始化。
private lateinit var mList: MutableList<String> fun main(args: Array<String>) { if (::mList.isInitialized) { mList.add("") } }
但如果我们在一个类中有一个lateinit属性,然后尝试在另一类中检查它是被初始化,如下所示:
class PreA{ lateinit var mList: MutableList<String> } class PreB{ val mPreA = PreA() fun print(){ if (mPreA::mList.isInitialized){ } } }
会报错:
Kotlin: Backing field of 'var mList: MutableList<String>' is not accessible at this point
因为该反射API的限定,当然inner class 是被允许的,具体设计细节参考官方
所以我们如有类似需求可以直接在目标类中添加新方法来检查lateinit属性:
class PreA{ lateinit var mList: MutableList<String> fun isListInitialised() = ::mList.isInitialized } class PreB{ val mPreA = PreA() fun print(){ if (mPreA.isListInitialised()){ mPreA.mList.add("") } } }
当然通过捕获UninitializedPropertyAccessException 异常也是可以
参考: StackOverflow
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。