學習 Kotlin 系列:被凍結的時間 const val

更新於 發佈於 閱讀時間約 3 分鐘

賦值 (Assign Value) 想成套繩圈的動作, var 的繩圈是可以鬆綁重來的,val 套住對方就不能換了,而進階版 const val 綁住對方之後,對方的時間就被凍結了。

其實,以 Kotlin 的程式語言設計來說,比起賦值 (Assign Value),用賦址 (Assign Reference) 來形容更為恰當,指定的是位址 (Reference, Address) 。開發的朋友可能聽過,以值呼叫,以位址呼叫(Call by value, Call by reference)。前者直接,後者間接。 Kotlin 全部都是 Call by reference 。

舉例來說,當我想呼叫小隊長小李時,前者是直接呼叫小李,後者呼叫的是小隊長。表面上結果是相同的,但其實只是現在相同。

以值來說,值因為是單純沒有指定性的,呼叫的只是小李的名字,而不是小李的人,當隔壁隊伍調來一個名字也是小李的人,電腦是辨別不出差異的。

以位址來說,假設小隊長是 var 設定,而這個呼叫延遲了數十年,也許那時已經換小小李上任小隊長,那麼結果就大大不同了;而如果是 val 設定,呼叫的還是小李,只是可能小李已經老了;而 const val 設定,讓小李一開始就是不會老的英靈

const val 時間凍結的效果自編譯 (Compile time) 完成起,相對於大部分變數是執行時 (Run time) 決定, const val 的設計不同,編譯時 (Compile time) 就決定了,也再不會變,所以 const val 只能寫在最頂層或是物件,因為這兩者也是編譯時決定。

raw-image

編譯 (Compile) 就是把我們寫的高階語言翻譯成電腦可以理解的機器語言,如果要細述過程會花太多時間,也不是本章重點,這裡我們只需知道編譯期 (Compile time) 早於執行期 (Run time) 。

因為時間早早就被凍結了,所以和純 val 不同,不能指定有屬性可變化的類別,只能指定基本型別 (Basic Types) 。 Kotlin 官網文件有列舉所有基本型別,有興趣的朋友可以查看。

raw-image

const val 因為是固定的,所以連本來準備的彈性變動空間都省下來了,用專業的術語來說就是提高效能。對於開發者來說,可讀性也提高,知道這是寫死的變數,要重寫時會特別留意。

大家都知道翻譯總是很難表達原意,因此更理解程式語言特性,程式就能寫得更精準,電腦也越能理解我們要做的事。

共勉之。

留言
avatar-img
留言分享你的想法!
avatar-img
Kate的沙龍
7會員
45內容數
和 Kotlin 相關的系列文章。 給程式初學者的「Kotlin 學習系列」 給正在實戰的工程師「Kotlin 實戰系列」
Kate的沙龍的其他內容
2023/03/22
比起說這是新技術,不如說是統一前端規格。 以前在不同框架下,類似功能的東西名字各不相同。比如輸入文字的物件,Android叫做EditText,iOS叫做UITextField,Html叫做TextBox或是input標籤。 這讓跨平台的開發者非常痛苦,痛不欲生。 而統一規格意味著,只要專心寫一套程
2023/03/22
比起說這是新技術,不如說是統一前端規格。 以前在不同框架下,類似功能的東西名字各不相同。比如輸入文字的物件,Android叫做EditText,iOS叫做UITextField,Html叫做TextBox或是input標籤。 這讓跨平台的開發者非常痛苦,痛不欲生。 而統一規格意味著,只要專心寫一套程
2021/11/23
去年停了近一年這裡的文章,其實是因為忙著將2020 iThome 鐵人賽的得獎作品——每年九月會舉辦的活動,連續三十天發表IT技術類文章——集結成書。 《老姐要用Kotlin寫專案:從 Server 到 Android APP 的開發生存日記》是以小說的敘事方式,將一對姐弟工程師合作
2021/11/23
去年停了近一年這裡的文章,其實是因為忙著將2020 iThome 鐵人賽的得獎作品——每年九月會舉辦的活動,連續三十天發表IT技術類文章——集結成書。 《老姐要用Kotlin寫專案:從 Server 到 Android APP 的開發生存日記》是以小說的敘事方式,將一對姐弟工程師合作
2021/11/22
此版本的目標畫面成果是: *金色名字。 *金色社交按鈕圖示,點擊按鈕另開對應的網頁或著顯示comming soon。 *名字和按鈕在網頁中央,如果網頁寬度不夠會換行,夠就不換行。
Thumbnail
2021/11/22
此版本的目標畫面成果是: *金色名字。 *金色社交按鈕圖示,點擊按鈕另開對應的網頁或著顯示comming soon。 *名字和按鈕在網頁中央,如果網頁寬度不夠會換行,夠就不換行。
Thumbnail
看更多
你可能也想看
Thumbnail
Kotlin 中存取類別的屬性是一個重要的操作,透過 getter 與 setter 宣告方式讓我們可以使用 var 或 val 來宣告屬性。本篇文章介紹了在類別中宣告屬性的範例以及存取與修改屬性的操作。
Thumbnail
Kotlin 中存取類別的屬性是一個重要的操作,透過 getter 與 setter 宣告方式讓我們可以使用 var 或 val 來宣告屬性。本篇文章介紹了在類別中宣告屬性的範例以及存取與修改屬性的操作。
Thumbnail
swift讀書筆記 Documentation Edit descriptiondocs.swift.org objective-c 的init 會return value,swift 不會。 所有的property都必須在Init()裡面設定初始值,或設定stored property,這種
Thumbnail
swift讀書筆記 Documentation Edit descriptiondocs.swift.org objective-c 的init 會return value,swift 不會。 所有的property都必須在Init()裡面設定初始值,或設定stored property,這種
Thumbnail
Python是一種物件導向的程式語言,它讓我們可以使用類別(Class)來定義和創建物件,想像一個物件就像是一個實體,可以包含資料和功能。 舉例來說,一個人可以被視為一個物件,它有姓名、年齡等資料,還可以說話、走路等功能。類別就像是一個模板,它描述了物件的特徵和行為。 Python中,我們使用
Thumbnail
Python是一種物件導向的程式語言,它讓我們可以使用類別(Class)來定義和創建物件,想像一個物件就像是一個實體,可以包含資料和功能。 舉例來說,一個人可以被視為一個物件,它有姓名、年齡等資料,還可以說話、走路等功能。類別就像是一個模板,它描述了物件的特徵和行為。 Python中,我們使用
Thumbnail
很多CV們交完音就沒事了,純熟的CV一句台詞試兩三次也就ok,會花多少時間呢?真的是看個人功力。但收完音後,才是後製們辛苦的開始。 在九號中和後製們討論過有打標和沒打標的情形下,對軌所花的時間可能是4倍以上。4倍是什麼概念?就是別人做1集,我可能做4集的概念。如果某團隊合作的CV都不打標,一年做4部
Thumbnail
很多CV們交完音就沒事了,純熟的CV一句台詞試兩三次也就ok,會花多少時間呢?真的是看個人功力。但收完音後,才是後製們辛苦的開始。 在九號中和後製們討論過有打標和沒打標的情形下,對軌所花的時間可能是4倍以上。4倍是什麼概念?就是別人做1集,我可能做4集的概念。如果某團隊合作的CV都不打標,一年做4部
Thumbnail
動詞的個性決定了句子需要的成份 (續上回) 如果要判別的話,可以用這個測試方法。。。
Thumbnail
動詞的個性決定了句子需要的成份 (續上回) 如果要判別的話,可以用這個測試方法。。。
Thumbnail
在Python中,所有東西都是物件。執行程式碼a = 5,會建立5這個物件,然後給a一個reference,這個reference就是告訴a,它的值放在記憶體的哪個位置,要用時,就到那裡去拿。 看到這裡,很直覺的反應是:這不就是C裡頭的pointer嗎?!然後就沒再多想了。
Thumbnail
在Python中,所有東西都是物件。執行程式碼a = 5,會建立5這個物件,然後給a一個reference,這個reference就是告訴a,它的值放在記憶體的哪個位置,要用時,就到那裡去拿。 看到這裡,很直覺的反應是:這不就是C裡頭的pointer嗎?!然後就沒再多想了。
Thumbnail
  感到很抱歉讓他遭遇這種感覺,讓他遲疑「解釋」可能會帶來更多不開心的疑問。正如同我留意不用「她」一樣(除非推理故事,敘事的第三人稱性別區分實在沒必要;)我其實也留意著不在指稱監護人的情況下用「爸爸媽媽」說明。不過這種事情通常只是我的自以為是而已。
Thumbnail
  感到很抱歉讓他遭遇這種感覺,讓他遲疑「解釋」可能會帶來更多不開心的疑問。正如同我留意不用「她」一樣(除非推理故事,敘事的第三人稱性別區分實在沒必要;)我其實也留意著不在指稱監護人的情況下用「爸爸媽媽」說明。不過這種事情通常只是我的自以為是而已。
Thumbnail
「選擇」是有能者的權利。這句話其實挺正確的。不妨想想那些哀怨、抱怨人生過頭的人,都是過著什麼樣的日子?
Thumbnail
「選擇」是有能者的權利。這句話其實挺正確的。不妨想想那些哀怨、抱怨人生過頭的人,都是過著什麼樣的日子?
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News