Kotlin lateinit与by lazy案例详解

lateinit 和 lazy 是 Kotlin 中的两种不同的延迟初始化的实现

lateinit 只用于变量 var,而 lazy 只用于常量 val

lazy 应用于单例模式(if-null-then-init-else-return),而且当且仅当变量被第一次调用的时候,委托方法才会执行。

lazy()是接受一个 lambda 并返回一个 Lazy 实例的函数,返回的实例可以作为实现延迟属性的委托: 第一次调用 get() 会执行已传递给 lazy() 的 lambda 表达式并记录结果, 后续调用 get() 只是返回记录的结果。

val lazyValue: String by lazy {
    println("computed!")
    "Hello"
}

fun main(args: Array) {
    println(lazyValue)
    println(lazyValue)
}

打印结果
computed!
Hello

Hello

比如这样的常见操作,只获取,不赋值,并且多次使用的对象

private val mUserMannager: UserMannager by lazy {
    UserMannager.getInstance()
}

再比如acitivity中控件初始化的操作,一般传统的进入界面就初始化所有的控件,而使用懒加载,只有用到时才会对控件初始化

//kotlin 封装:
fun  Activity.bindView(id: Int): Lazy = lazy {
    viewFinder(id) as V
}

//acitivity中扩展调用
private val Activity.viewFinder: Activity.(Int) -> View?
    get() = { findViewById(it) }


//在activity中的使用姿势
val mTextView by bindView(R.id.text_view)
mTextView.text="执行到我时,才会进行控件初始化"

lateinit 则用于只能生命周期流程中进行获取或者初始化的变量,比如 Android 的 onCreate()

@Inject
@field:Named("home")
lateinit var pagerAdapter:FragmentStatePagerAdapter

再比如

class App : Application() {
    init {
        instance = this
    }

    @Inject lateinit var apiComponent: ApiComponent
    override fun onCreate() {
        super.onCreate()
        DaggerApiComponent.builder().apiModule(ApiModule()).appModule(AppModule(this)).build().inject(this)
    }

    companion object {
        lateinit var instance: App

    }
}

到此这篇关于Kotlin lateinit与by lazy案例详解的文章就介绍到这了,更多相关Kotlin lateinit与by lazy内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(Kotlin lateinit与by lazy案例详解)