轉載自:簡書buchuqi2677的文章
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
}
}