Kotlin如何安全访问lateinit变量的实现
时间:2022-07-27
本文章向大家介绍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
以上就是本文的全部内容,希望对大家的学习有所帮助。
- 用 Doc2Vec 得到文档/段落/句子的向量表达
- 手把手用 IntelliJ IDEA 和 SBT 创建 scala 项目
- 项目中记录影响性能的缓慢数据库查询
- memory_profiler的使用
- 使用line_profiler查看api接口函数每行代码执行时间
- GAN 的 keras 实现
- 双向 LSTM
- scrapy回调函数传递参数
- python更新数据库脚本两种方法
- 使聊天机器人具有个性
- 遇到502错误,invalid request block size 解决方法
- python中json.loads,dumps,jsonify使用
- sqlalchemy和flask-sqlalchemy几种分页操作
- 一个 tflearn 情感分析小例子
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法