Meta 發布了一篇博客表示,正在將其 Android 應用的 Java 代碼遷移到 Kotlin,并分享了這一過程中的一些經驗。
該公司認為,Kotlin 是一種流行的 Android 開發語言,與 Java 相比具有一些關鍵優勢?!耙虼?,在我們努力使我們的開發工作流程更加高效的過程中,將 Meta 的 Android 開發轉向 Kotlin 是非常合理的。..。..Kotlin 通常被認為是一種比 Java 更好的語言,在年度 Stack Overflow 開發者調查中,它的好感度要高于 Java?!?/p>
除了受歡迎程度外,Meta 還將最新的 Kotlin 版本與 Java 11(可用于 Android 開發的最新版本)進行了比較,并得出了 Kotlin 的一些主要優勢:可空性、函數式編程、更短的代碼、以及領域特定語言 (DSL) / 類型安全構建器等。
Facebook 軟件工程師 Omer Strulovich 指出,Meta 旗下幾個流行的 Android 應用 --Facebook、Instagram、Messenger、Portal 和 Quest 都已經開始從 Java 轉向 Kotlin。截至目前,Facebook、Messenger 和 Instagram 的 Android 應用程序都有超過 100 萬行 Kotlin 代碼,并且轉換率正在提高。Meta 的 Android 代碼庫總共已包含有超過 1000 萬行的 Kotlin 代碼。作為此次遷移的一部分,Meta 透露其也正在開源用于操作 Kotlin 代碼的各種示例和實用程序。
不過,采用 Kotlin 也有一些不能忽視的缺點。博客內容指出,比如:兩種語言的混合代碼庫需要長時間的處理維護;以及 Kotlin 與 Java 相比,流行度還是存在明顯的差距,這意味著 Kotlin 可用的工具也更少。更糟糕的是所有 Kotlin 工具還都需要考慮 Kotlin 和 Java 的互操作性,這使得它們的實現就變得復雜。
最大的問題還在于構建時間。“我們從一開始就知道 Kotlin 的構建時間會比 Java 的要長。該語言及其生態系統更加復雜,Java 在優化其編譯器方面領先了 20 年。由于我們擁有多個大型應用程序,較長的構建時間可能會對我們的開發人員體驗產生負面影響?!?/p>
如何處理遷移
Meta 稱,遷移到 Kotlin 既簡單又非常復雜。因為 Kotlin 的設計允許從 Java 進行簡單的轉換,并具有經過深思熟慮的互操作性。這種設計使 JetBrains 能夠為開發人員社區提供 J2K,即 IntelliJ/Android Studio 中的 Java 到 Kotlin 轉換器。但 J2K 不是萬能的,遷移中的有些情況仍然很復雜。
遷移之前,該公司考慮了兩個選擇:
一個是可以使用 Kotlin 在 Meta 上編寫新代碼,但將大部分現有代碼保留在 Java 中。
還有一個是可以嘗試將幾乎所有內部代碼轉換為 Kotlin。
第一個選項的優勢很明顯,即少得多的工作量;但是這種方法也有兩個明顯的缺點。首先,在 Kotlin 和 Java 代碼之間實現互操作性引入了 Kotlin 中 platform types 的使用。platform types 會導致運行時空指針取消引用,從而導致崩潰,破壞了純 Kotlin 代碼提供的靜態安全優勢。在一些復雜的情況下,Kotlin 的空檢查省略還可能漏掉空值通過,進而引發空指針異常。例如,如果 Kotlin 代碼調用由 Java 接口實現的 Kotlin 接口,就會發生這種情況。其他問題包括 Java 無法將類型參數標記為可空性(直到最近才修復),以及 Kotlin 的重載規則考慮了可空性,而 Java 的重載規則卻沒有。
第二個缺點是考慮到 Meta 的大多數軟件開發都需要修改現有代碼?!叭绻覀兊拇蟛糠执a都是用 Java 編寫的,我們就無法讓我們的開發人員充分享受 Kotlin 的樂趣。由于遷移是一個漫長的過程,期望每個工程師在接觸文件之前將文件轉換為 Kotlin 既費力又低效?!?/p>
因此,Meta 方面最終選擇了第二條選項,決定將幾乎所有代碼轉換為 Kotlin。而在嘗試為現有應用程序引入 Kotlin 時,Meta 也遇到了很多麻煩,例如需要更新 Redex 以支持 Java 不生成的字節碼模式。以及使用的某些內部庫依賴于在編譯期間進行字節碼轉換來獲取更好的性能。而將其作為 Kotlin 編譯的一部分運行時,這部分代碼則無法生效。為此,Meta 專門構建了解決工具。
此外,他們還發現在現有工具中存在的一些差異。例如代碼審查或 wiki 中缺少 Kotlin 語法高亮顯示。“我們更新了我們正在使用的庫 Pygments,以使體驗與 Java 相媲美。我們更新了一些內部代碼修改工具,以便能夠處理 Kotlin。我們還構建了 Ktfmt,這是一個基于 google-java-format 的代碼和理念的確定性 Kotlin 格式化程序。”
準備好所有工具后,Meta 就可以正式開始批量轉換大量代碼。“隨著我們工具的改進,我們已經能夠將相當大的一部分代碼轉換成 Kotlin。我們的代碼庫中已經有超過 1000 萬行 Kotlin 代碼,而且 Meta 的大多數 Android 開發人員現在都在編寫 Kotlin 代碼”。平均而言,此次遷移使代碼行數減少了 11%。
Meta 方面表示,其向 Kotlin 的遷移仍在進行中并在加速。“我們已經允許 Meta 的任何想要使用 Kotlin 的 Android 開發人員這樣做,并為他們提供了工具來輕松地將現有代碼遷移到 Kotlin。Kotlin 仍然缺少一些我們在使用 Java 時已經習慣的工具和優化。但我們正在努力縮小這些差距。隨著我們取得進展以及這些工具和庫的成熟,我們還將努力將它們反饋給社區?!?/p>
審核編輯 :李倩
-
Android
+關注
關注
12文章
3945瀏覽量
128005 -
JAVA
+關注
關注
19文章
2976瀏覽量
105211 -
代碼
+關注
關注
30文章
4836瀏覽量
69119
原文標題:已超1000萬行代碼,Java再次輸給了Kotlin...
文章出處:【微信號:OSC開源社區,微信公眾號:OSC開源社區】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
Spire.XLS for Android via Java組件說明
![Spire.XLS for <b class='flag-5'>Android</b> via <b class='flag-5'>Java</b>組件說明](https://file1.elecfans.com/web3/M00/07/1B/wKgZO2eTFFKACjKPAAAlbAyqU-k118.png)
從TMS320VC5509遷移到TMS320VC5509A
![從TMS320VC5509<b class='flag-5'>遷移到</b>TMS320VC5509A](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
TMS320C645X DSP從EDMA 2.0版遷移到EDMA 3.0版
![TMS320C645X DSP從EDMA 2.0版<b class='flag-5'>遷移到</b>EDMA 3.0版](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
從TMS320DM35x遷移到TMS320DM36x器件
![從TMS320DM35x<b class='flag-5'>遷移到</b>TMS320DM36x器件](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
從TMS320DM6467遷移到TMS320DM6467T
![從TMS320DM6467<b class='flag-5'>遷移到</b>TMS320DM6467T](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
從TMS320DM6446 594MHz遷移到810MHz
![從TMS320DM6446 594MHz<b class='flag-5'>遷移到</b>810MHz](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
評論