Kotlin lateinit 和 by lazy

lateinit 和 lazy 是 Kotlin 中的兩種不同的延遲初始化的實現

lateinit 只用于變量 var,而 lazy 只用于常量 val
lazy 應用于單例模式(if-null-then-init-else-return),而且當且僅當變量被第一次調用的時候,委托方法才會執行。

lazy()是接受一個 lambda 并返回一個 Lazy <T> 實例的函數,返回的實例可以作為實現延遲屬性的委托: 第一次調用 get() 會執行已傳遞給 lazy() 的 lambda 表達式并記錄結果, 后續調用 get() 只是返回記錄的結果。

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

fun main(args: Array<String>) {
    println(lazyValue)
    println(lazyValue)
}

打印結果
computed!
Hello

Hello

比如這樣的常見操作,只獲取,不賦值,并且多次使用的對象


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

再比如acitivity中控件初始化的操作,一般傳統的進入界面就初始化所有的控件,而使用懶加載,只有用到時才會對控件初始化

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

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


//在activity中的使用姿勢
val mTextView by bindView<TextView>(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

    }
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容