定义全局 android.widget var/val 时的“lateinit”或“by lazy”

Posted

技术标签:

【中文标题】定义全局 android.widget var/val 时的“lateinit”或“by lazy”【英文标题】:"lateinit" or "by lazy" when defining global android.widget var/val 【发布时间】:2017-10-18 19:30:47 【问题描述】:

定义全局android.widget 变量时,例如TextView,最好使用lateinit 还是by lazy?我最初认为使用 by lazy 会更好,因为它是不可变的,但我不完全确定。

by lazy 示例:

class MainActivity: AppCompatActivity() 

    val helloWorldTextView by lazy  findViewById(R.id.helloWorldTextView) as TextView 

    override fun onCreate(savedInstanceState: Bundle?) 
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        updateTextView(helloWorldTextView)
    

    fun updateTextView(tv: TextView?) 
        tv?.setText("Hello?")
    

lateinit 示例:

class MainActivity: AppCompatActivity() 

    lateinit var helloWorldTextView: TextView

    override fun onCreate(savedInstanceState: Bundle?) 
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        helloWorldTextView = findViewById(R.id.helloWorldTextView) as TextView
        updateTextView(helloWorldTextView)
    

    fun updateTextView(tv: TextView?) 
        tv?.setText("Hello?")
    

在定义全局android.widget var/val 时,使用其中一个有什么好处?使用by lazy 定义android.widget val 是否有任何陷阱?该决定是否仅基于您想要一个可变值还是不可变值?

【问题讨论】:

【参考方案1】:

by lazy 有一个陷阱。小部件属性将是只读的,因此 技术上 是最终的(在 Java 术语中)。但是没有书面保证 onCreate() 只在一个实例中被调用一次。 findViewById() 也可以返回 null

所以最好使用lateinit,你会得到一个异常告诉你val是否在onCreate()之前使用。

第三种可能性是Android synthetic properties。那么你就完全不用担心变量了。

import kotlinx.android.synthetic.main.activity_main.*

helloWorldTextView.text = "Hello?"

【讨论】:

这些很重要。还有,哇!这个扩展是惊人的。感谢您将其包含在您的回答中。 onCreate(…) 确实每个 Activity 实例调用一次,但 lazy 委托无论如何都没有绑定到它,它只是在第一次调用时初始化,在这种情况下完全可以。当然,合成属性无论如何都更容易 lazy 也可能导致内存泄漏 Fragments bignerdranch.com/blog/kotlin-when-to-use-lazy-or-lateinit

以上是关于定义全局 android.widget var/val 时的“lateinit”或“by lazy”的主要内容,如果未能解决你的问题,请参考以下文章

Android API之android.widget.Filterable

多个 Android Widget 实例仅更新最后一个小部件

Android Widget - 一个动作,多个按钮

Android.widget,textView 不能转换为 android.widget,button

android.widget.RadioGroup 不能转换为 android.widget.RadioButton

android.widget.LinearLayout 无法转换为 android.widget.TextView