首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Kotlin】类的初始化 ④ ( lateinit 延迟初始化 | ::属性名称.isInitialized 检查属性是否初始化 | lazy 惰性初始化 )

文章目录 一、lateinit 延迟初始化 ( ::属性名称.isInitialized 检查属性是否初始化 ) 二、lazy 惰性初始化 一、lateinit 延迟初始化 ( ::属性名称.isInitialized...检查属性是否初始化 ) ---- 在定义属性时 , 可以使用 lateinit 关键字 设置该属性的 延迟初始化 , 在 实例对象 创建时不进行初始化 , 在使用该属性之前对其进行初始化即可 ; 对于...lateinit 延迟初始化 的属性 , 在使用前可以执行 ::属性名称.isInitialized 检查 , 查看该属性是否进行了初始化操作 ; 代码示例 : class Hello{ lateinit...} fun main() { // 实例化对象时, name 属性不需要初始化 var hello = Hello() println("实例对象初始化完毕") Thread.sleep...(1000) // 在调用 name 属性后, 才初始化 name 属性 println("name = ${hello.name}") } 执行结果 : 实例对象初始化完毕 初始化

1.6K10

浅谈Kotlin(六):lateinit、by lazy 使用

Kotlin中有两种延迟初始化的方式。一种是lateinit var,一种是by lazy。...*/ 也可以这么写: 表示我先不给一个初始值,编译期的时候也无需进行非空判断,后面我会找时机给他赋值 即late的作用为编译期在检查时不要因为属性变量未被初始化而报错 lateinit var datas...:ArrayList 当然若在使用该变量的时候仍未给赋值,则会报错 Caused by: kotlin.UninitializedPropertyAccessException: lateinit...property datas has not been initialized lateinit使用限制: 只能用来修饰类属性,不能用来修饰局部变量, 只能用来修饰对象,不能用来修饰基本类型(因为基本类型的属性在类加载后的准备阶段都会被初始化为默认值...时再进行初始化 打印结果: lazyParm初始化 lazyParm->aaa by lazy使用限制: 要求属性声明为val,即不可变变量,在java中相当于被final修饰。

5.7K32
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Kotlin:关键字之lateinit

    在Kotlin中定义变量或者属性都是需要初始化值的,并且其都是private的,但是有些时候对于变量或者属性只需要声明,但是不需要初始化,则kotlin提供了lateinit关键字来实现: class...,char,short ,int,long,float,double) 也许有人会问到为什么为什么不可以修饰原始数据类型 对于对象类型,Kotlin使用 null 值,以标记 lateinit 属性尚未初始化...对于原始类型,没有这样的值,因此无法将属性标记为未初始化并提供的诊断信息lateinit 需要提供。...新手来说,应该抛开 Java 式的写法,牢记类属性的三种初始化方式: 主构造函数内定义属性,使用传入的参数初始化属性; 类体内定义属性,同时初始化; 类体内定义属性,init 块里初始化。...var age: Int //会报错1 3.lateinit可以在任何位置初始化并且可以初始化多次。

    1K20

    【C++干货基地】面向对象核心概念 | 访问限定符 | 类域 | 实例化 | 类对象模型

    类体中内容称为类的 成员 :类中的变量称为类的属性或 成员变量 ; 类中的函数称为类的方法或者 成员函数 。...void Person::PrintPersonInfo() { cout << _name << " " << _gender << " " << _age << endl; } 三、类的实例化...用类类型创建对象的过程,称为类的实例化 类是对对象进行描述的,是一个模型一样的东西,限定了类有哪些成员,定义出一个类并没有分配实际的内存空间来存储它; 比如说我们在类里面定义的成员变量,其实只是对他进行了声明...return 0; } 比 一个类可以实例化出多个对象,实例化出的对象 占用实际的物理空间,存储类成员变量 类实例化出对象就像现实中使用建筑设计图建造出房子,类就像是设计图 只有使用图纸建造除真正的方式才回真正的物理空间...四、类的对象模型 4.1 类的大小如何计算?

    7400

    Kotlin中的延迟属性(lazy properties)

    属于Kotlin中的委托属性这一章中的标准委托 延迟属性Lazy lazy() 是接受一个lambda 并返回一个 Lazy 实例的函数,返回的实例可以作为实现延迟属性的委托。...,将对代理实例的引用存储在类对象中,并为与委托实例一起使用的属性生成getter。...除了val之外,lateinit不能用于可空属性和Java原语类型(这是因为null用于未初始化的值);所以如果你需要在类中存在的支持字段,请使用lateinit; lateinit var可以从对象被看到的任何地方被初始化...从一个框架代码的内部,多个初始化方案是可能的单一类的不同对象。 by lazy { ... }反过来又定义了属性的唯一初始化器,只能通过覆盖子类中的属性进行更改。...延迟属性Lazy 与 lateinit 使用总结 lateinit用于外部初始化:当需要外部资料通过调用方法初始化您的值时。

    3.5K30

    Kotlin —  lateinit vs lazy

    Kotlin属性初始化 如果不想在一开始就初始化一个属性,那么你可以使用下面两个关键字。 ① lateinit ② lazy lateinit lateinit的意思是后面再初始化。...通常情况下,声明为非null类型的属性必须先初始化。但是,这在有些时候不是很方便。 要处理这种情况,可以使用lateinit修饰符修饰属性。...fun do(){ user.eat() } } a、lateinit只能用于var声明的类变量,并且属性没有自定义getter或setter方法。...lazy()是一个函数,它接受一个lambda并返回一个lazy实例,它可以作为一个实现lazy属性的委托:get()的第一个调用执行传递给lazy()的lambda并记录结果,随后调用get()只返回记录的结果...① lateinit var 可以从任何你能看到对象的地方初始化。如果你想你的属性从外部被初始化,这时候可以使用lateinit。 ② lazy只能用于val属性,而lateinit只能应用于变量。

    72130

    Kotlin 中使用 Hilt 的开发实践

    而上述这两点并不互斥,而且在很多情况下,您的类既可以注入依赖项同时也包含依赖。 使依赖项可注入 如果需要在 Hilt 中使某个类变得可注入,您需要告诉 Hilt 如何创建该类的实例。...var milk: Milk @Inject lateinit var coffee: Coffee ... } 如果类是入口点,这里特指使用了 @AndroidEntryPoint 注解的类...也可以添加 lateinit 来避免字段空值,因为它们在注入之前的初始值就是 null。 请注意作为字段注入依赖项的场景仅仅适合类必须包含无参构造函数的情况,比如 Activity。...详情请查看 将任意类转换为入口点。 ViewModel ViewModel 是一个特例: 因为框架会创建它们,它既不是被直接实例化的,也不是 Android 入口点。...lateinit var moreMilk: Milk //这里的实例和上面的相同 ... } 在本例中,milk 和 moreMilk 指向同一个 OatMilk 实例。

    1.1K30

    Kotlin的延迟初始化: lateinit var和by lazy

    (因为基本类型的属性在类加载后的准备阶段都会被初始化为默认值)。...lateinit var的作用也比较简单,就是让编译期在检查时不要因为属性变量未被初始化而报错。...Kotlin相信当开发者显式使用lateinit var 关键字的时候,他一定也会在后面某个合理的时机将该属性对象初始化的(然而,谁知道呢,也许他用完才想起还没初始化)。...->T)创建的Lazy实例对象赋值给nameXXdelegate; 当该属性被调用,即其getter方法被调用时返回nameXXdelegate.getVaule(),而nameXXdelegate.getVaule...然后,虽然两者都可以推迟属性初始化的时间,但是lateinit var只是让编译期忽略对属性未初始化的检查,后续在哪里以及何时初始化还需要开发者自己决定。

    3.3K10

    第4章 类与面向对象编程第4章 类与面向对象编程

    (name='Jack', age=29, sex='M') 另外,我们也可以先声明属性,等到构造实例对象的时候再去初始化属性值,那么我们的Person类可以声明如下 class Person1 {...lateinit var name: String // lateinit 关键字表示该属性延迟初始化 var age: Int = 0 // lateinit 关键字不能修饰 primitive...: , 父类需要在这里使用构造函数初始化 class Circle : Shape() class Triangle : Shape() 因为抽象的概念在问题领域中没有对应的具体概念,所以抽象类是不能够实例化的...不能实例化抽象类 我们只能实例化它的继承子类。代码示例如下 val r = Rectangle() println(r is Shape) // true 现在我们有了抽象类,但是没有成员。...但在语法层面,接口本身不是类,不能实例化接口,我们只能实例化它的实现类。 接口是用来建立类与类之间的协议。实现该接口的实现类必须要实现该接口的所有方法。

    1.8K20

    Kotlin入门(22)适配器的简单优化

    lateinit的意思是延迟初始化,它放在var或者val前面,表示被修饰的变量属于延迟初始化属性,即使没有初始化也仍然是非空的。...}     //ViewHolder中的属性使用关键字lateinit延迟初始化     inner class ViewHolder {         lateinit var ll_item:...var tv_desc: TextView     } } 以上的Kotlin代码总算有点模样了,虽然总体代码还不够精简,但是至少清晰明了,其中主要运用了Kotlin的以下三项技术: 1、构造函数和初始化参数放在类定义的首行...lateinit,表示该属性为延迟初始化属性; 网格视图 在前面的列表视图一小节中,给出了Kotlin改写后的适配器类,通过关键字lateinit固然避免了麻烦的空校验,可是控件对象迟早要初始化的呀...}     //ViewHolder中的属性在构造时初始化     inner class ViewHolder(val view: View) {         val ll_item: LinearLayout

    1.4K10

    从源码角度分析 Kotlin by lazy 的实现

    lazy 函数会创建一个 SynchronizedLazyImpl 类,并传入 initializer 参数。...Lazy 接口的 value 属性用于获取当前 Lazy 实例的延迟初始化值。一旦初始化后,它不得在此 Lazy 实例的剩余生命周期内更改。...但是,如果某个值已由另一个线程初始化,则将返回该值而不执行初始化。 总结 lateinit 修饰的变量也可以延迟初始化,但并不是不用初始化,它需要在生命周期流程中进行获取或者初始化。...lateinit和by lazy的区别: lateinit 只能用于修饰变量 var,不能用于可空的属性和 Java 的基本类型。 lateinit 可以在任何位置初始化并且可以初始化多次。...lazy 在第一次被调用时就被初始化,以后调用该属性会返回之前的结果。

    1.6K30

    【Kotlin】变量简介 ( 可空类型 | lateinit | 初始化判定 | 非空类型 | !! 与 ? 修饰符 | ?= ?. ?: 运算符 | 抽象属性变量)

    = null 赋空值 ; ③ 非空变量 ( 引用类型 ) 使用 lateinit 修饰 ; ④ 抽象属性变量不初始化 ; 2 . !! 与 ? 修饰符 : 仅对于 可空类型 有效 , ?...特殊情况 : 如果是非空对象是抽象类中的抽象属性 , 那么可以不进行初始化 , 但在其实现中 , 也是必须进行初始化或者延迟初始化的 ; III . 非空变量不能赋空 ---- 1 ....其它类中判定 : 如果要在其它类中判定本类某个属性是否已经初始化 , 需要定义一个 public 方法 , 提供判定接口 , 如下代码示例 : 5 ....变量不用初始化的特殊情况 : 抽象类 的 抽象属性 , 可以不进行初始化 , 但此时也不能使用 ; 该属性实现的时候 , 重写的属性必须进行初始化操作 , 与普通变量要求一样 ; abstract class...Variable(){ //抽象类的抽象属性可以不用初始化 abstract var age : Int } //抽象类的实现类必须进行初始化 class Student() : Variable

    2.7K20

    Android面试题之Kotlin的几种常见的类

    初始化的顺序 主构造函数里声明的属性 类级别的属性赋值 init初始化块里的属性赋值和函数调用 次构造函数里的属性赋值和函数调用 延迟初始化 lateinit关键字用来延迟初始化 isInitialized...可以检查是否初始化完成 class classtest { var name = "Java" lateinit var code:String fun ready() {...return "ccc" } lateinit和by lazy lateinit只修饰var,lazy修饰val lateinit var只能用来修饰类属性,不能用来修饰局部变量,并且只能用来修饰对象...lateinit var让编译期在检查时不要因为属性变量未被初始化而报错,也就是去掉了属性上的@NotNull修饰 by lazy后面的表达式只在第一次调用时执行一次,后续只返回结果 by lazy可以使用于类属性或者局部变量...by lazy初始化操作是线程安全的 初始化注意点 使用初始化块时,顺序非常重要,必须确保块中的所有属性已经完成初始化 初始化块中的函数里所用到得属性,也要确保已经初始化完成 类里面的属性按从上往下顺序初始化

    8610

    【Jetpack】使用 Room 框架访问 Android 平台 SQLite 数据库 ( 导入依赖 | 定义 Entity 实体类 | 定义 Dao 数据库访问对象接口 | 定义数据库实例类 )

    * 不需要插入到数据库中 * 使用 @Ignore 注解修饰该属性字段 */ @Ignore lateinit var studentInfo: String...定义的 RoomDatabase 数据库实例类 是一个 抽象类 , 需要继承 RoomDatabase 抽象类 , 同时要使用 @Database 注解修饰 , @Database(entities...* 设置该数据类对应数据库中的一张数据表, 表名为 student * 该数据库表中的数据对应一个 Student 类实例对象 */ @Entity(tableName = "student")...* 不需要插入到数据库中 * 使用 @Ignore 注解修饰该属性字段 */ @Ignore lateinit var studentInfo: String...RoomDatabase 数据库实例类 需要继承 RoomDatabase 抽象类 , 使用 @Database 注解修饰 该抽象类 ; 其中需要 定义 获取 数据库访问 对象 的抽象函数 ; 将该类定义成

    48430

    Kotlin修炼指南(三)——奇技淫巧

    lazy 通过lazy函数,可以实现在首次使用到的时候才去实例化。...通过lateinit,自己控制变量的初始化。...object Singleton { fun xxx() { } } 反编译后看生成代码,这就是一个典型的饿汉式单例,借助静态代码块初始化的锁,初始化单例实例,从而实现单例效果。...扩展属性也是类似,获取的扩展属性会生成为一个静态的get函数,同时这个静态函数的第一个参数就是该类的实例对象,设置的扩展属性会转化为一个静态的set函数,同时这个静态函数的第一个参数就是该类的实例对象。...装饰器类与原始类拥有相同行为的方法不用修改,只需要直接转发给原始类的实例,需要修改的函数,实现新的功能即可。

    78420

    【Jetpack】Room 中的销毁重建策略 ( 创建临时数据库表 | 拷贝数据库表数据 | 删除旧表 | 临时数据库表重命名 )

    - 更改数据模型 | 创建 Migration 迁移类 | 修改数据库版本 | 代码示例 ) 基础上 , 升级数据库版本 4 ; 数据库 版本 2 和 3 分别在 数据库 版本 1 的基础上新增了一个字段...* 设置该数据类对应数据库中的一张数据表, 表名为 student * 该数据库表中的数据对应一个 Student 类实例对象 */ @Entity(tableName = "student")...* 不需要插入到数据库中 * 使用 @Ignore 注解修饰该属性字段 */ @Ignore lateinit var studentInfo: String...* 设置该数据类对应数据库中的一张数据表, 表名为 student * 该数据库表中的数据对应一个 Student 类实例对象 */ @Entity(tableName = "student")...* 不需要插入到数据库中 * 使用 @Ignore 注解修饰该属性字段 */ @Ignore lateinit var studentInfo: String

    47240

    最强总结 | 带你快速搞定kotlin开发(上篇)

    可以看到实例化Person对象时,并没有声明变量类型,这就是Kotlin的“类型推断”,会自动推断出是Person类型的变量,而且是不需要Java中的new关键字的。...强行调用符 1.5 lateinit关键字 lateinit var person: Person person = Person() 我们总有场景在声明的时候不知道赋什么值,在后面才去赋值的场景...,那么就可以使用lateinit关键字。...但是只能在以下场景下使用: var声明的变量 lateinit修饰的变量不可空、不能是基本数据类型、不能有初始值 构造器中初始化的变量不需要使用lateinit关键字 1.6 类型判断 if(p is...1.10 静态函数和属性 // 方法在类的外面【包级函数】或者叫【顶层函数】 fun getSomething(): Int { return 0 } class Person {} //

    54810
    领券