91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

將其Android應(yīng)用的Java代碼遷移到Kotlin

OSC開(kāi)源社區(qū) ? 來(lái)源:OSC開(kāi)源社區(qū) ? 作者:OSC開(kāi)源社區(qū) ? 2022-10-28 15:15 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Meta 發(fā)布了一篇博客表示,正在將其 Android 應(yīng)用的 Java 代碼遷移到 Kotlin,并分享了這一過(guò)程中的一些經(jīng)驗(yàn)。

該公司認(rèn)為,Kotlin 是一種流行的 Android 開(kāi)發(fā)語(yǔ)言,與 Java 相比具有一些關(guān)鍵優(yōu)勢(shì)?!耙虼?,在我們努力使我們的開(kāi)發(fā)工作流程更加高效的過(guò)程中,將 Meta 的 Android 開(kāi)發(fā)轉(zhuǎn)向 Kotlin 是非常合理的。..。..Kotlin 通常被認(rèn)為是一種比 Java 更好的語(yǔ)言,在年度 Stack Overflow 開(kāi)發(fā)者調(diào)查中,它的好感度要高于 Java。”

除了受歡迎程度外,Meta 還將最新的 Kotlin 版本與 Java 11(可用于 Android 開(kāi)發(fā)的最新版本)進(jìn)行了比較,并得出了 Kotlin 的一些主要優(yōu)勢(shì):可空性、函數(shù)式編程、更短的代碼、以及領(lǐng)域特定語(yǔ)言 (DSL) / 類型安全構(gòu)建器等。

Facebook 軟件工程師 Omer Strulovich 指出,Meta 旗下幾個(gè)流行的 Android 應(yīng)用 --Facebook、Instagram、Messenger、Portal 和 Quest 都已經(jīng)開(kāi)始從 Java 轉(zhuǎn)向 Kotlin。截至目前,F(xiàn)acebook、Messenger 和 Instagram 的 Android 應(yīng)用程序都有超過(guò) 100 萬(wàn)行 Kotlin 代碼,并且轉(zhuǎn)換率正在提高。Meta 的 Android 代碼庫(kù)總共已包含有超過(guò) 1000 萬(wàn)行的 Kotlin 代碼。作為此次遷移的一部分,Meta 透露其也正在開(kāi)源用于操作 Kotlin 代碼的各種示例和實(shí)用程序。

不過(guò),采用 Kotlin 也有一些不能忽視的缺點(diǎn)。博客內(nèi)容指出,比如:兩種語(yǔ)言的混合代碼庫(kù)需要長(zhǎng)時(shí)間的處理維護(hù);以及 Kotlin 與 Java 相比,流行度還是存在明顯的差距,這意味著 Kotlin 可用的工具也更少。更糟糕的是所有 Kotlin 工具還都需要考慮 Kotlin 和 Java 的互操作性,這使得它們的實(shí)現(xiàn)就變得復(fù)雜。

最大的問(wèn)題還在于構(gòu)建時(shí)間?!拔覀儚囊婚_(kāi)始就知道 Kotlin 的構(gòu)建時(shí)間會(huì)比 Java 的要長(zhǎng)。該語(yǔ)言及其生態(tài)系統(tǒng)更加復(fù)雜,Java 在優(yōu)化其編譯器方面領(lǐng)先了 20 年。由于我們擁有多個(gè)大型應(yīng)用程序,較長(zhǎng)的構(gòu)建時(shí)間可能會(huì)對(duì)我們的開(kāi)發(fā)人員體驗(yàn)產(chǎn)生負(fù)面影響。”

如何處理遷移

Meta 稱,遷移到 Kotlin 既簡(jiǎn)單又非常復(fù)雜。因?yàn)?Kotlin 的設(shè)計(jì)允許從 Java 進(jìn)行簡(jiǎn)單的轉(zhuǎn)換,并具有經(jīng)過(guò)深思熟慮的互操作性。這種設(shè)計(jì)使 JetBrains 能夠?yàn)殚_(kāi)發(fā)人員社區(qū)提供 J2K,即 IntelliJ/Android Studio 中的 Java 到 Kotlin 轉(zhuǎn)換器。但 J2K 不是萬(wàn)能的,遷移中的有些情況仍然很復(fù)雜。

遷移之前,該公司考慮了兩個(gè)選擇:

一個(gè)是可以使用 Kotlin 在 Meta 上編寫新代碼,但將大部分現(xiàn)有代碼保留在 Java 中。

還有一個(gè)是可以嘗試將幾乎所有內(nèi)部代碼轉(zhuǎn)換為 Kotlin。

第一個(gè)選項(xiàng)的優(yōu)勢(shì)很明顯,即少得多的工作量;但是這種方法也有兩個(gè)明顯的缺點(diǎn)。首先,在 Kotlin 和 Java 代碼之間實(shí)現(xiàn)互操作性引入了 Kotlin 中 platform types 的使用。platform types 會(huì)導(dǎo)致運(yùn)行時(shí)空指針取消引用,從而導(dǎo)致崩潰,破壞了純 Kotlin 代碼提供的靜態(tài)安全優(yōu)勢(shì)。在一些復(fù)雜的情況下,Kotlin 的空檢查省略還可能漏掉空值通過(guò),進(jìn)而引發(fā)空指針異常。例如,如果 Kotlin 代碼調(diào)用由 Java 接口實(shí)現(xiàn)的 Kotlin 接口,就會(huì)發(fā)生這種情況。其他問(wèn)題包括 Java 無(wú)法將類型參數(shù)標(biāo)記為可空性(直到最近才修復(fù)),以及 Kotlin 的重載規(guī)則考慮了可空性,而 Java 的重載規(guī)則卻沒(méi)有。

第二個(gè)缺點(diǎn)是考慮到 Meta 的大多數(shù)軟件開(kāi)發(fā)都需要修改現(xiàn)有代碼。“如果我們的大部分代碼都是用 Java 編寫的,我們就無(wú)法讓我們的開(kāi)發(fā)人員充分享受 Kotlin 的樂(lè)趣。由于遷移是一個(gè)漫長(zhǎng)的過(guò)程,期望每個(gè)工程師在接觸文件之前將文件轉(zhuǎn)換為 Kotlin 既費(fèi)力又低效?!?/p>

因此,Meta 方面最終選擇了第二條選項(xiàng),決定將幾乎所有代碼轉(zhuǎn)換為 Kotlin。而在嘗試為現(xiàn)有應(yīng)用程序引入 Kotlin 時(shí),Meta 也遇到了很多麻煩,例如需要更新 Redex 以支持 Java 不生成的字節(jié)碼模式。以及使用的某些內(nèi)部庫(kù)依賴于在編譯期間進(jìn)行字節(jié)碼轉(zhuǎn)換來(lái)獲取更好的性能。而將其作為 Kotlin 編譯的一部分運(yùn)行時(shí),這部分代碼則無(wú)法生效。為此,Meta 專門構(gòu)建了解決工具。

此外,他們還發(fā)現(xiàn)在現(xiàn)有工具中存在的一些差異。例如代碼審查或 wiki 中缺少 Kotlin 語(yǔ)法高亮顯示?!拔覀兏铝宋覀冋谑褂玫膸?kù) Pygments,以使體驗(yàn)與 Java 相媲美。我們更新了一些內(nèi)部代碼修改工具,以便能夠處理 Kotlin。我們還構(gòu)建了 Ktfmt,這是一個(gè)基于 google-java-format 的代碼和理念的確定性 Kotlin 格式化程序?!?/p>

準(zhǔn)備好所有工具后,Meta 就可以正式開(kāi)始批量轉(zhuǎn)換大量代碼。“隨著我們工具的改進(jìn),我們已經(jīng)能夠?qū)⑾喈?dāng)大的一部分代碼轉(zhuǎn)換成 Kotlin。我們的代碼庫(kù)中已經(jīng)有超過(guò) 1000 萬(wàn)行 Kotlin 代碼,而且 Meta 的大多數(shù) Android 開(kāi)發(fā)人員現(xiàn)在都在編寫 Kotlin 代碼”。平均而言,此次遷移使代碼行數(shù)減少了 11%。

Meta 方面表示,其向 Kotlin 的遷移仍在進(jìn)行中并在加速?!拔覀円呀?jīng)允許 Meta 的任何想要使用 Kotlin 的 Android 開(kāi)發(fā)人員這樣做,并為他們提供了工具來(lái)輕松地將現(xiàn)有代碼遷移到 Kotlin。Kotlin 仍然缺少一些我們?cè)谑褂?Java 時(shí)已經(jīng)習(xí)慣的工具和優(yōu)化。但我們正在努力縮小這些差距。隨著我們?nèi)〉眠M(jìn)展以及這些工具和庫(kù)的成熟,我們還將努力將它們反饋給社區(qū)。”

審核編輯 :李倩

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Android
    +關(guān)注

    關(guān)注

    12

    文章

    4026

    瀏覽量

    134038
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    3001

    瀏覽量

    116457
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4968

    瀏覽量

    74007

原文標(biāo)題:已超1000萬(wàn)行代碼,Java再次輸給了Kotlin...

文章出處:【微信號(hào):OSC開(kāi)源社區(qū),微信公眾號(hào):OSC開(kāi)源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    深入解析rk平臺(tái)Android Bootloader核心代碼:從啟動(dòng)流程到AVB驗(yàn)證

    android_bootloader.c的核心代碼,帶你讀懂Android設(shè)備從Bootloader到內(nèi)核的完整啟動(dòng)邏輯,以及開(kāi)發(fā)者關(guān)注這些代碼的核心價(jià)值。 一、
    的頭像 發(fā)表于 01-22 07:06 ?286次閱讀
    深入解析rk平臺(tái)<b class='flag-5'>Android</b> Bootloader核心<b class='flag-5'>代碼</b>:從啟動(dòng)流程到AVB驗(yàn)證

    電子材料抗離子遷移方案!東亞合成 IXE/IXEPLAS,智美行科技免費(fèi)試樣

    離子遷移是電子材料失效的主要原因之一,封裝材料中的 Na?、Cl?、Cu2?、Ag?等雜質(zhì)離子,在電場(chǎng)、溫濕度等環(huán)境因素作用下,會(huì)從材料內(nèi)部遷移到布線表面或間隙中,形成導(dǎo)電通路,引發(fā)布線腐蝕、電路
    的頭像 發(fā)表于 12-16 16:07 ?680次閱讀
    電子材料抗離子<b class='flag-5'>遷移</b>方案!東亞合成 IXE/IXEPLAS,智美行科技免費(fèi)試樣

    無(wú)質(zhì)量損失的數(shù)據(jù)遷移:Nikon SLM Solutions信賴3Dfindit企業(yè)版

    使用轉(zhuǎn)換器將CAD數(shù)據(jù)從一個(gè)系統(tǒng)傳輸?shù)搅硪粋€(gè)系統(tǒng),但這往往會(huì)導(dǎo)致數(shù)據(jù)的質(zhì)量下降。因此,該公司決定使用3Dfindit企業(yè)版將CAD數(shù)據(jù)遷移到新系統(tǒng),便不會(huì)造成任何質(zhì)量損失。這樣,在保持最高數(shù)據(jù)質(zhì)量
    發(fā)表于 11-25 10:06

    如何基于開(kāi)發(fā)板RK3568 Android 11強(qiáng)制所有應(yīng)用橫屏展示

    RK3568 Android 11強(qiáng)制所有應(yīng)用橫屏展示,1、打開(kāi)frameworks/base/core/java/android/content/pm/parsing/component
    的頭像 發(fā)表于 11-07 16:07 ?742次閱讀
    如何基于開(kāi)發(fā)板RK3568 <b class='flag-5'>Android</b> 11強(qiáng)制所有應(yīng)用橫屏展示

    Arm Neoverse CPU上大代碼Java應(yīng)用的性能測(cè)試

    Java 是互聯(lián)網(wǎng)領(lǐng)域廣泛使用的編程語(yǔ)言。Java 應(yīng)用的一些特性使其性能表現(xiàn)與提前編譯的原生應(yīng)用(例如 C 程序)大相徑庭。由于 Java 字節(jié)碼無(wú)法直接在 CPU 上執(zhí)行,因此通常運(yùn)行時(shí)在
    的頭像 發(fā)表于 11-05 11:25 ?764次閱讀
    Arm Neoverse CPU上大<b class='flag-5'>代碼</b>量<b class='flag-5'>Java</b>應(yīng)用的性能測(cè)試

    Java 25正式發(fā)布,重要特性詳解(附代碼示例):靈活構(gòu)造函數(shù)體、模塊導(dǎo)入聲明、AOT方法分析等

    Java 25現(xiàn)已發(fā)布,更多新特性來(lái)了!配合Perforce JRebel,代碼修改即時(shí)生效,無(wú)需重啟服務(wù),即可實(shí)現(xiàn)“改完就看效果”。新特性+快工具,讓你的Java開(kāi)發(fā)體驗(yàn)雙倍提升!
    的頭像 發(fā)表于 10-29 13:16 ?1475次閱讀
    <b class='flag-5'>Java</b> 25正式發(fā)布,重要特性詳解(附<b class='flag-5'>代碼</b>示例):靈活構(gòu)造函數(shù)體、模塊導(dǎo)入聲明、AOT方法分析等

    如何在Keil中將NuMicro BSP從Arm編譯器5遷移到編譯器6?

    在Keil中將NuMicro BSP從Arm編譯器5遷移到編譯器6!
    發(fā)表于 08-20 06:29

    Perforce JRebel 簡(jiǎn)介:即時(shí)加載代碼變更,加速Java應(yīng)用開(kāi)發(fā)

    Perforce JRebel 專為Java開(kāi)發(fā)提速而生!支持跳過(guò)構(gòu)建與重新部署,實(shí)時(shí)加載代碼變更,支持100+框架,無(wú)縫集成主流IDE與應(yīng)用服務(wù)器。
    的頭像 發(fā)表于 08-14 14:35 ?804次閱讀
    Perforce JRebel 簡(jiǎn)介:即時(shí)加載<b class='flag-5'>代碼</b>變更,加速<b class='flag-5'>Java</b>應(yīng)用開(kāi)發(fā)

    ArkUI-X平臺(tái)橋接Bridge說(shuō)明

    介紹如何通過(guò)平臺(tái)橋接編寫自定義的Android、iOS平臺(tái)代碼。ArkUI側(cè)具體用法請(qǐng)參考Bridge API,Android側(cè)參考BridgePlugin,iOS側(cè)參考BridgePlugin
    發(fā)表于 06-19 23:12

    ArkUI-X與Android橋接通信之方法回調(diào)

    ) => { console.error(\'error: \' + JSON.stringify(err)); }); 2.在Android側(cè)實(shí)現(xiàn)被調(diào)用的方法。 // xxx.java
    發(fā)表于 06-08 22:16

    ArkUI-X與Android消息通信

    ) => { console.log(\'error: \' + JSON.stringify(err)); }); 2.Android側(cè)接收來(lái)自ArkUI側(cè)的數(shù)據(jù)。 // xxx.java
    發(fā)表于 06-08 22:15

    Kuikly鴻蒙版正式開(kāi)源 —— 揭秘卓越性能適配之旅

    、小程序Q2開(kāi)源) 原生級(jí)性能體驗(yàn):得益于 KMP 跨平臺(tái)能力,Kuikly 將 Kotlin 代碼編譯成各個(gè)平臺(tái)原生產(chǎn)物,從而獲得接近原生平臺(tái)的執(zhí)行性能。 Kotlin語(yǔ)言驅(qū)動(dòng),純?cè)_(kāi)發(fā)工具鏈:復(fù)用
    發(fā)表于 06-04 16:46

    從Keil MDK到IAR EWARM:通過(guò)工程遷移實(shí)現(xiàn)項(xiàng)目資產(chǎn)的更好管理

    對(duì)于需要統(tǒng)一開(kāi)發(fā)環(huán)境或涉及多核架構(gòu)(如Cortex-A/R)的項(xiàng)目,越來(lái)越多的用戶選擇從Keil MDK遷移到IAR EWARM。這就會(huì)面臨著需要將之前的Keil MDK工程遷移到IAR EWARM的問(wèn)題。本文將介紹如何高效完成這一遷移
    的頭像 發(fā)表于 05-08 09:03 ?1308次閱讀
    從Keil MDK到IAR EWARM:通過(guò)工程<b class='flag-5'>遷移</b>實(shí)現(xiàn)項(xiàng)目資產(chǎn)的更好管理

    Java開(kāi)發(fā)者必備的效率工具——Perforce JRebel是什么?為什么很多Java開(kāi)發(fā)者在用?

    Perforce JRebel是一款Java開(kāi)發(fā)效率工具,旨在幫助java開(kāi)發(fā)人員更快地編寫更好的應(yīng)用程序。JRebel可即時(shí)重新加載對(duì)代碼的修改,無(wú)需重啟或重新部署應(yīng)用程序,就能讓開(kāi)發(fā)者即時(shí)看到
    的頭像 發(fā)表于 04-27 13:44 ?866次閱讀
    <b class='flag-5'>Java</b>開(kāi)發(fā)者必備的效率工具——Perforce JRebel是什么?為什么很多<b class='flag-5'>Java</b>開(kāi)發(fā)者在用?

    請(qǐng)問(wèn)將項(xiàng)目從RT1024遷移到RT1064的最快方法是什么?

    我正在將我的項(xiàng)目從基于 RT1024 遷移到基于 RT1064 的下一代產(chǎn)品,是否有快速的方法,或者我只能手動(dòng)完成? 謝謝!
    發(fā)表于 03-31 06:15