lateinit 和 lazy 是Ktolin 中的两种不同的延迟初始化实现
lateinit只用于变量var,而lazy只用于常量 val
lazy应用于单例模式(if-null-then-init-else-return),而且当且仅当变量被第一次调用的时候,委托方法才会执行
lazy()是接受一个lambda并返回一个Lazy<T>实例的函数,返回的实例可以作为实现延迟属性的委托:第一次调用get()会执行已传递给lazy()的lambda表达式并记录结果,后续调用get()只是返回记录的结果。
val lazyValueL:String by lazy{
println("computed!")
"Hello"
}
fun main(args: Array<String>){
println(lazyValue)
println(lazyValue)
}
打印结果
computed!
Hello
Hello
比如这样的常见操作,只获取,不赋值,并且多次使用的对象
private val mUserManager:UserManager by lazy{
Usermanager.getInstance()
}
再比如activity中控件初始化的操作,一般传统的进入界面就初始化所有控件,而使用懒加载,只有用到时才会对控件初始化
//kotlin封装
fun<V:View>activity.bindView(id:Int):Lazy<V>= lazy{
viewFinder(id) as V
}
//activity 中扩展调用
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
}
}
网友评论