扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
Kotlin设计之初就是不允许非null变量在声明期间不进行初始化的,为了解决这个问题,Kotlin lateinit 允许我们先声明一个变量,然后在程序执行周期的将来某个时候将其初始化,让编译检查时不会 因为属性变量未被初始化而报错。如果未初始化将导致以下异常:
成都创新互联公司-专业网站定制、快速模板网站建设、高性价比桑植网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式桑植网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖桑植地区。费用合理售后完善,10年实体公司更值得信赖。
kotlin.UninitializedPropertyAccessException: lateinit property mList has not been initialized
所以我们在 Kotlin 1.2及更高版本上,经常使用基于反射的API 快速检查lateinit属性是否已初始化。
private lateinit var mList: MutableListfun main(args: Array ) { if (::mList.isInitialized) { mList.add("") } }
但如果我们在一个类中有一个lateinit属性,然后尝试在另一类中检查它是被初始化,如下所示:
class PreA{ lateinit var mList: MutableList} class PreB{ val mPreA = PreA() fun print(){ if (mPreA::mList.isInitialized){ } } }
会报错:
Kotlin: Backing field of 'var mList: MutableList
' is not accessible at this point
因为该反射API的限定,当然inner class 是被允许的,具体设计细节参考官方
所以我们如有类似需求可以直接在目标类中添加新方法来检查lateinit属性:
class PreA{ lateinit var mList: MutableListfun isListInitialised() = ::mList.isInitialized } class PreB{ val mPreA = PreA() fun print(){ if (mPreA.isListInitialised()){ mPreA.mList.add("") } } }
当然通过捕获UninitializedPropertyAccessException 异常也是可以
参考: StackOverflow
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流