網站首頁 編程語言 正文
這里比較與解釋 Lazy
與 Lateinit
的用法。
Lateinit
有時變量的值在其聲明的位置不可用。 一個例子是在 Activity 或 Fragment 中使用的 UI widget。 直到 onCreate 或 onCreateView 方法運行,在整個 Activity 中用于引用這些 widget 的變量才能被初始化。 本例中的 submitButton,下面的代碼是如果我們不使用 lateinit 的情況:
class HomeFragment: Fragment() { // we will provide actual value later private var submitButton: Button? = null }
我們知道,一個變量必須被初始化。 一個標準的做法就是使這個變量可以為空,并用 null 初始化它。
但是,使用 nullable 類型的問題在于,無論何時在代碼中使用 submitButton,都必須檢查可空性。 例如:submitButton?.setOnClickListener { .. }
。我們必須在 submitButton 后面加上問號。
這個時候,我們就可以使用 lateinit:
class HomeFragment: Fragment() { private lateinit var submitButton: Button // will initialize later }
另外一個例子:
private lateinit var courseName: String // demo function to get course name using the courseId fun fetchCourseName(courseId: String) { courseName = courseRepository.getCourseName(courseId) // this is an example, you can add other suff according to your usecase }
我們需要非常確定 lateinit 變量在訪問它之前會被初始化,否則會報錯:
UninitializedPropertyAccessException: lateinit property courseName has not been initialized
如果我們不確定這個 lateinit 變量是否為空,那么可以使用 isInitialized 添加一個檢查來檢查 lateinit 變量是否已初始化:
if(this::courseName.isInitialized) { // access courseName } else { // some default value }
何時使用 lateinit 初始化
- 如果變量是可變的(mutable)并且可以在稍后階段初始化。
- 必須在使用變量之前對其進行初始化。
- 使用 var 關鍵字。
Lazy
某些類的對象初始化非常繁重,并且花費了太多時間,從而導致整個類創建過程的延遲。
例如,假設我們有一個名為 HeavyClass 的類,并且我們需要該 HeavyClass 的對象在其他名為 SomeClass 的類中:
class SomeClass { private val heavyObject: HeavyClass = HeavyClass() }
在這里,我們正在創建一個 heavy object,這將導致 SomeClass 的創建緩慢或延遲。 在某些情況下,我們可能不需要 HeavyClass 對象。 因此,在這種情況下,lazy 關鍵字起到作用:
class SomeClass { private val heavyObject: HeavyClass by lazy { HeavyClass() } }
現在,使用 Lazy 的好處是只有在調用對象時才會創建對象。
使用惰性的另一個好處是,一旦對象被初始化,調用時再次使用同一個對象。
比如:
class SomeClass { private val heavyObject: HeavyClass by lazy { println("Heavy Object initialised") HeavyClass() } fun accessObject() { println(heavyObject) } } fun main(args: Array<String>) { val someClass = SomeClass() println("SomeClass initialised") someClass.accessObject() someClass.accessObject() }
打印
SomeClass initialised?
Heavy Object initialised?
HeavyClass@2a84aee7?
HeavyClass@2a84aee7
何時使用 Lazy 初始化
- 除非你調用它,否則變量不會被初始化。
- 初始化變量一次; 然后在整個代碼中使用相同的值。
- 在 val 屬性的情況下使用,即作為同一對象的只讀屬性將在整個程序中共享
原文鏈接:https://blog.csdn.net/zyctimes/article/details/127955926
- 上一篇:沒有了
- 下一篇:沒有了
相關推薦
- 2022-11-14 React中的生命周期詳解_React
- 2022-07-13 Docker的資源控制管理
- 2022-03-08 使用C語言實現本地socke通訊的方法_C 語言
- 2022-08-06 Golang泛型與反射的應用詳解_Golang
- 2022-12-11 React?state狀態屬性用法講解_React
- 2022-07-19 Python數據分析?Numpy?的使用方法_python
- 2023-07-09 Golang 列表list
- 2022-02-21 MyBatis There is no getter for property named ‘xxx
- 欄目分類
-
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支