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

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

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

重新構(gòu)想前端開發(fā)!Kotlin推出新功能

jf_8lIj6kO1 ? 來源:InfoQ ? 2023-02-23 09:58 ? 次閱讀

近日,JetBrains 發(fā)布了 Kotlin 1.8.20 beta 版本,其中包括一項(xiàng)名為“Kotlin/Wasm”的實(shí)驗(yàn)性功能,明確將 WebAssembly 設(shè)為編譯目標(biāo)。據(jù)介紹,新版本依賴于原生 Wasm 垃圾收集功能 WasmGC,后者同樣處于早期開發(fā)階段。

JetBrains 總結(jié)了 Kotlin/Wasm 的優(yōu)勢:

  • 與 wasm32 Kotlin/Native 目標(biāo)相比,Kotlin/Wasm 的編譯速度更快,因?yàn)楹笳卟槐厥褂?LLVM。

  • 由于 Wasm 垃圾收集支持,與 wasm32 目標(biāo)相比,Kotlin/Wasm 與 JS 的互操作性、與瀏覽器的集成更容易。

  • 與 Kotlin/JS 和 JavaScript 相比,Kotlin/Wasm 應(yīng)用程序啟動時(shí)間可能更快,因?yàn)?Wasm 具有緊湊且易于解析的字節(jié)代碼。

  • 與 Kotlin/JS 和 JavaScript 相比,Kotlin/Wasm 應(yīng)用程序運(yùn)行時(shí)性能更快,因?yàn)?Wasm 是一種靜態(tài)類型語言。

不過,目前還沒有 IDE 為 Kotlin/Wasm 提供支持。JetBrains 在版本發(fā)行說明中提到,“我們以開箱即用的形式,為 Kotlin/Wasm 提供 Kotlin 標(biāo)準(zhǔn)庫(stdlib)和測試庫(kotlin/test)。”

7bd7c1d2-b30c-11ed-bfe3-dac502259ad0.png

瀏覽器中運(yùn)行的 Kotlin/Wasm 演示

此前,通過基于 LLVM 的 Kotlin-Native 編譯指向和 LLVM Wasm 支持,Kotlin 已經(jīng)能夠在某種程度上實(shí)現(xiàn)向 Wasm 的編譯,這種舊方法被稱為 wasm32。隨著新版本的發(fā)布,該方法將成為被棄用的多種 Kotlin/Native 編譯目標(biāo)之一。

作為一種 JVM 語言,Kotlin 具備垃圾收集機(jī)制,但此前 Wasm 一直無法原生支持垃圾收集,這就要求各垃圾收集語言自行提供解決方案。Wasm-gc 就是其中一項(xiàng)提案,承諾“對高級語言做出有效支持”。此次,這一設(shè)計(jì)有望超越自定義解決方案,并減少應(yīng)用程序的二進(jìn)制文件大小。Wasm-gc 可通過瀏覽器 Flag 在最新版本的 Chrome、Firefox 和 Edge 上啟用。

Kotlin 的“通用型語言”理想

早在 2017 年,主流瀏覽器都已經(jīng)支持 WebAssembly。隨著 WebAssembly 的蓬勃發(fā)展,各種編程語言也在增加對其的支持。比如,C/C++、Rust、Golang 等已支持將語言編譯到 WebAssembly 目標(biāo)平臺,Lua、JavaScript、Ruby 和 Python 等支持將語言的虛擬機(jī)或解釋器編譯到 WebAssembly 平臺。

2021 年,WebAssembly 開源項(xiàng)目開始支持 GC(垃圾回收器),為實(shí)現(xiàn) WebAssembly 支持像 Java、Kotlin 這樣的前端語言做準(zhǔn)備。同年,Kotlin 程序語言開發(fā)團(tuán)隊(duì)更新了發(fā)展路線,其中的一個(gè)重點(diǎn)就是增加 WebAssembly 支持。

Kotlin 總項(xiàng)目經(jīng)理 Egor Tolstoy 表示,他們認(rèn)為 WebAssembly 會成為未來創(chuàng)建豐富網(wǎng)頁應(yīng)用程序的新標(biāo)準(zhǔn),而 Kotlin 必需要能夠完美的提供支持。因此官方火力全開,組建了一個(gè)專門團(tuán)隊(duì)來開發(fā) Kotlin/Wasm 工作,并且與 WebAssembly 垃圾回收提案作者緊密合作,要實(shí)現(xiàn) Kotlin 語言的基本功能、函數(shù)庫和基本 Gradle 的支持,還要添加實(shí)驗(yàn)性 JavaScript 互通操作功能。

Kotlin 在 2017 Google 發(fā)表聲明后總被當(dāng)成是安卓專用開發(fā)語言,但實(shí)際上,Kotlin 正在積極地向多平臺語言演進(jìn),即“通用型語言”。

如今,JetBrains 提供了多個(gè)支持多平臺的庫,如 kotlinx.coroutines、kotlinx.serialization、kotlinx-datetime。而 Kotlin 社區(qū)也緊跟著這樣的趨勢發(fā)展,出現(xiàn)了愈來愈多的庫、框架來支持多平臺,如 Arrow、Okio、Apollo 等在新版本中都支持了多平臺開發(fā)。

Kotlin/Wasm 究竟有什么潛力

在最初的設(shè)計(jì)中,WebAssembly 只是 C、C++ 或 Rust 這些低級語言的編譯目標(biāo)。至于 Python、Ruby 甚至是 JavaScript 等動態(tài)語言,能充當(dāng)解釋性的虛擬機(jī)即可。

但 WebAssembly 垃圾收集(GC)的貢獻(xiàn)者們正努力把它打造成垃圾收集語言(例如 Java、Kotlin 或 Dart)的編譯目標(biāo),并停止使用 JavaScript 作為 Web 字節(jié)碼。此外,他們還考慮把其他語言也都轉(zhuǎn)化成前端開發(fā)中的理想選項(xiàng),而不必像 TypeScript 那樣把一切先編譯成 JavaScript。

請注意,這些語言已經(jīng)能夠在各個(gè)應(yīng)用程序內(nèi)提供自己的自定義垃圾收集,借此實(shí)現(xiàn)對 WebAssembly 的編譯。這樣做的缺點(diǎn)就是這樣生成的工件會更大,所以也不知道 WasmGC 真正推出時(shí),原來的這種處理方式還有沒有競爭力。

WasmGC 的實(shí)現(xiàn)源自 Chrome、Firefox、Edge 和 Safari 四大瀏覽器的一個(gè)持續(xù)性項(xiàng)目,目前需要使用 Flag 加以啟用(例如,在 Chrome 或 Edge 上,需要使用 --js-flags=--experimental-wasm-gc 命令行參數(shù))。正是因?yàn)檫_(dá)不到開箱即用的程度,所以該技術(shù)目前還沒能得到廣泛采用。

但是,當(dāng) WasmGC 步入第四階段并在大多數(shù)瀏覽器中實(shí)現(xiàn)開箱即用后,能夠利用 WasmGC 的語言將迎來顯著的競爭優(yōu)勢。

在 VMware 從事 Spring Framework 工作的 Sébastien Deleuze 稱,Kotlin/Wasm 很早就在關(guān)注 WasmGC,谷歌也在使用 J2CL 和 Dart 在 Google Sheets 中將 Java 編譯為 WasmGC。

前端(及全棧)開發(fā)

“因?yàn)橐?a target="_blank">開發(fā)者同時(shí)了解 Kotlin 和 JavaScript 兩套生態(tài)系統(tǒng),所以我個(gè)人一直對 Kotlin/JS 不太感冒,但 Kotlin/Wasm 確實(shí)是個(gè)重塑前端開發(fā)面貌的好機(jī)會。”Deleuze 表示,“當(dāng)然,Kotlin/Wasm 必須要提供良好的 JavaScript 互操作性(它也確實(shí)做到了),并作為可選項(xiàng)?!?/p>

目前,Kotlin/Wasm 提供 DOM API,所以某些 Kotlin/Wasm 前端框架可能已經(jīng)足夠成為前端開發(fā)的理想選擇。Deleuze 表示自己可能也會試試將 Kotlin/Wasm 用于前端開發(fā),再配合 Spring Boot Kotlin/JVM 后端實(shí)現(xiàn) Kotlin 中的全棧開發(fā)。

但從另一個(gè)角度來看,WebAssembly 還有更多值得發(fā)掘的亮點(diǎn)。如果 Compose for Web(Android 上使用的多平臺版 Jetpack Compose)能夠用 Kotlin/Wasm 代替 Kotlin/JS 來完美執(zhí)行基于 Canvas 的像素渲染,結(jié)果又會如何?(稍做劇透,其實(shí)已經(jīng)實(shí)現(xiàn)了。)

如果 Kotlin/Wasm 能夠用 WebAssembly 來取代 JavaScript,支持一種新的 Jamstack 架構(gòu),結(jié)果又會如何?

WebAssembly 組件模型

要想充分理解 Kotlin/Wasm 的巨大潛力,就不能不提 WebAssembly 組件模型。正是它的存在,讓我們能使用任意支持 WebAssembly 的語言,為 WebAssembly 開發(fā)組件。這項(xiàng)工作的基石正是 WIT 格式,可用于描述導(dǎo)入和展出并生成特定于語言的 binding。

Deleuze 親自實(shí)踐了一下,看看 WIT 是如何被轉(zhuǎn)譯成 Kotlin 的,結(jié)果看起來還不錯(cuò)。例如,其嘗試將 WIT variant 定義為:

variant filter {
    all,
    none,
    some(list<string>),
 }

轉(zhuǎn)譯出的 Kotlin 代碼如下:

sealed interface Filter {
   object All : Filter
   object None : Filter
   class Some(val value: List): Filter
}

利用 String 提供的 null 安全特性,WIT option能夠被準(zhǔn)確轉(zhuǎn)譯為 Kotlin 慣用的選項(xiàng)值處理方式。在 Deleuze 看來,Kotlin 協(xié)程也將成為組件模型異步支持綁定中一個(gè)強(qiáng)大的競爭優(yōu)勢。

用 warg 實(shí)現(xiàn) WebAssembly 包管理

大家可能會好奇 WebAssembly 要如何發(fā)布和使用。別擔(dān)心,面向 WebAssembly 包的標(biāo)準(zhǔn)化管理項(xiàng)目 Warg,有望帶來各種包 repo 實(shí)例,其中的關(guān)鍵就是 WebAssembly 包 repo 將支持多語言。

沒錯(cuò),Maven Central 或者 NPM 在 Java 和 JavaScript 之外的語言中也有使用,但無論是生產(chǎn)還是消費(fèi)都擺脫不了“二等公民”的陰影。Warg 和 WebAssembly 將真正把多語言組件推向全新的高度。

Deleuze 預(yù)測,像 Rust/C/C++ 這樣的語言將主要用于生產(chǎn) Wasm 組件(強(qiáng)調(diào)效率,只為非共享方法提供極小、甚至干脆不提供運(yùn)行時(shí));而 Kotlin/Wasm 這類能利用 WasmGC 的語言,則主要負(fù)責(zé)構(gòu)建使用這些組件的應(yīng)用程序。當(dāng)然,Rust 也可以用來開發(fā) Wasm 應(yīng)用程序,但 Deleuze 猜測 WasmGC 語言才是這類用例中的主導(dǎo)者。

WASI

所謂 WASI,簡言之就是在定義標(biāo)準(zhǔn)化系統(tǒng)接口(包括文件系統(tǒng)、時(shí)鐘、環(huán)境變量、命令行參數(shù)或者標(biāo)準(zhǔn)輸入 / 輸出)應(yīng)該如何被公開給 Wasm 應(yīng)用程序。機(jī)器學(xué)習(xí)、人工智能或者云存儲等其他用例也可以通過 WASI 進(jìn)行標(biāo)準(zhǔn)化。

Kotlin/Wasm 目前還不支持 WASI,但開發(fā)團(tuán)隊(duì)已經(jīng)提供低級 API 實(shí)現(xiàn)。有趣的是,只需要提供 WASI 平臺中的特定部分,就能使用 Kotlin 的多平臺庫(例如 kotlinx-datetime 或 Okio)。

“ Kotlin/Wasm + WASI ”將并發(fā)出驚人的潛能:它可以提供 Kotlin/JVM 的替代方案,將應(yīng)用程序部署到云端、邊緣甚至是 Serverless 函數(shù)的形式;也被大量用作容器鏡像的替代方案,能在幾微秒內(nèi)完成實(shí)例化、提供更高的安全性且不依賴于任何特定硬件操作系統(tǒng)。這樣的特性可能讓人想起 Java 在 1995 年提出的“一次編寫,隨處運(yùn)行”(WORA)口號。

目前實(shí)現(xiàn)這一愿景的主要障礙在于,Wasmtime 等純 WASI 運(yùn)行時(shí)還不支持 WasmGC。目前,運(yùn)行 Kotlin/Wasm WASI 應(yīng)用程序的主要途徑是利用 Node WASI 支持。

附:如何啟用 Kotlin/Wasm

要啟用 Kotlin/Wasm 并對其進(jìn)行測試,請更新您的 build.gradle.kts 文件:

plugins {
    kotlin("multiplatform") version "1.8.20-Beta"
}


kotlin {
    wasm {
        binaries.executable()
        browser {
        }
    }
    sourceSets {
        val commonMain by getting
        val commonTest by getting {
            dependencies {
                implementation(kotlin("test"))
            }
        }
        val wasmMain by getting
        val wasmTest by getting
    }
}

可查看包含 Kotlin/Wasm 示例的 GitHub 存儲庫

要運(yùn)行 Kotlin/Wasm 項(xiàng)目,您需要更新目標(biāo)環(huán)境的設(shè)置:

  • Chrome,對于版本 109 或更高版本:

1. 在您的瀏覽器中轉(zhuǎn)到 chrome://flags/#enable-webassembly-garbage-collection。

2. 重新啟動瀏覽器應(yīng)用程序。

  • Firefox,對于版本 111 或更高版本:

3. 在您的瀏覽器中轉(zhuǎn)到 about:config。

4. 啟用 javascript.options.wasm_function_references 和 javascript.options.wasm_gc 選項(xiàng)。

5. 重新啟動瀏覽器應(yīng)用程序。

  • Edge,對于版本 109 或更高版本:

使用命令行參數(shù)運(yùn)行應(yīng)用程序 -- js-flags=--experimental-wasm-gc。

審核編輯 :李倩



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

    關(guān)注

    37

    文章

    3198

    瀏覽量

    57364
  • 編譯
    +關(guān)注

    關(guān)注

    0

    文章

    646

    瀏覽量

    32672
  • kotlin
    +關(guān)注

    關(guān)注

    0

    文章

    60

    瀏覽量

    4166

原文標(biāo)題:重新構(gòu)想前端開發(fā)!Kotlin 推出新功能:無需同時(shí)了解 Kotlin 和 JavaScript

文章出處:【微信號:玩轉(zhuǎn)VS Code,微信公眾號:玩轉(zhuǎn)VS Code】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    Meta旗下社交平臺Threads推出新功能

    Meta旗下的新興社交平臺Threads近期宣布了一系列新功能推出,旨在為企業(yè)用戶和數(shù)字創(chuàng)作者提供更加便捷和強(qiáng)大的內(nèi)容管理工具。此次更新不僅豐富了平臺的交互體驗(yàn),還進(jìn)一步提升了數(shù)據(jù)透明度與發(fā)布效率。
    的頭像 發(fā)表于 08-16 18:00 ?1054次閱讀

    亞馬遜云科技推出多項(xiàng)安全服務(wù)新功能

    在近日舉辦的re:Inforce 2024全球大會上,亞馬遜云科技(Amazon Web Services, AWS)再次彰顯了其在云計(jì)算安全領(lǐng)域的領(lǐng)先地位,推出了一系列激動人心的安全服務(wù)新功能。這些新功能不僅提升了用戶數(shù)據(jù)的安
    的頭像 發(fā)表于 06-12 15:14 ?308次閱讀

    OpenAI推出ChatGPT實(shí)時(shí)數(shù)據(jù)分析新功能

    近日,OpenAI在ChatGPT中推出了令人矚目的實(shí)時(shí)數(shù)據(jù)分析新功能。這一創(chuàng)新功能為用戶提供了前所未有的數(shù)據(jù)處理體驗(yàn),極大地提升了數(shù)據(jù)處理的便捷性。
    的頭像 發(fā)表于 05-20 11:28 ?490次閱讀

    艾為電子推出高壓觸覺反饋產(chǎn)品三大新功能

    隨著線性馬達(dá)技術(shù)研究的持續(xù)深入,艾為電子推出高壓觸覺反饋產(chǎn)品三大新功能,賦予用戶前所未有的沉浸式體驗(yàn)。
    的頭像 發(fā)表于 04-20 10:07 ?413次閱讀
    艾為電子<b class='flag-5'>推出</b>高壓觸覺反饋產(chǎn)品三大<b class='flag-5'>新功能</b>

    DEKRA被CSA指定為Zigbee統(tǒng)一測試工具開發(fā)和優(yōu)化新功能和測試用例

    DEKRA德凱被CSA聯(lián)盟(Connectivity Standards Alliance,CSA)指定負(fù)責(zé)為Zigbee統(tǒng)一測試工具(Zigbee Unified Test Harness,ZUTH)開發(fā)和優(yōu)化新功能和測試用例。
    的頭像 發(fā)表于 04-09 14:10 ?366次閱讀

    GitHub推出新功能:智能掃描代碼潛在漏洞

    “代碼掃描”功能還能預(yù)防新手引入新的問題,并支持在設(shè)定的日期和時(shí)間進(jìn)行掃描,或者讓特定事件(如推送到倉庫中)觸發(fā)掃描。若AI判定代碼內(nèi)可能存在隱患,GitHub將在倉庫中發(fā)出預(yù)警,待用戶修正引發(fā)求救信號的部分后,再撤銷警告。
    的頭像 發(fā)表于 03-21 14:55 ?441次閱讀

    微軟Teams應(yīng)用商城已突破 2000 款應(yīng)用,即將再添新功能

    3月19日,微軟宣布Microsoft Teams應(yīng)用商城已迅猛發(fā)展至超過兩千款應(yīng)用,且該擴(kuò)展速度持續(xù)維持高水平。為了促進(jìn)更多人了解和使用此類應(yīng)用,微軟推出多項(xiàng)獨(dú)特新功能及特性。
    的頭像 發(fā)表于 03-19 10:19 ?379次閱讀

    模擬前端功能有哪些

    模擬前端(AFE)的功能豐富多樣,它在電子系統(tǒng)中扮演著至關(guān)重要的角色。作為模擬信號與數(shù)字信號之間的橋梁,模擬前端主要實(shí)現(xiàn)信號的采集、調(diào)理、轉(zhuǎn)換以及進(jìn)一步的處理,確保信號能夠準(zhǔn)確、穩(wěn)定地傳遞給后續(xù)的數(shù)字系統(tǒng)。
    的頭像 發(fā)表于 03-16 15:23 ?702次閱讀

    愛立信推出認(rèn)知軟件新功能

    日前,愛立信宣布在其專為運(yùn)營商設(shè)計(jì)的認(rèn)知軟件組合中,新增采用“可解釋性人工智能(Explainable AI,XAI)”的新功能,進(jìn)一步加速在網(wǎng)絡(luò)設(shè)計(jì)和優(yōu)化中采用人工智能后的價(jià)值轉(zhuǎn)化。
    的頭像 發(fā)表于 02-22 09:22 ?5116次閱讀

    web前端開發(fā)前端開發(fā)的區(qū)別

    Web前端開發(fā)前端開發(fā)是兩個(gè)相似但略有不同的概念。本文將詳細(xì)討論這兩者之間的區(qū)別。 定義和范圍: Web前端
    的頭像 發(fā)表于 01-18 09:54 ?2545次閱讀

    社區(qū)說|引領(lǐng)高效編程風(fēng)向 Kotlin 前沿技術(shù)開發(fā)深度剖析

    隨著全球化進(jìn)程不斷推進(jìn),多線遠(yuǎn)程合作編程已是業(yè)內(nèi)大勢所趨。作為一種跨平臺、靜態(tài)類型的編程語言,Kotlin 在近幾年來受到了開發(fā)者們的青睞,并依托技術(shù)研發(fā)取得了令人矚目的創(chuàng)新性突破。 在 12 月
    的頭像 發(fā)表于 12-20 09:30 ?234次閱讀
    社區(qū)說|引領(lǐng)高效編程風(fēng)向 <b class='flag-5'>Kotlin</b> 前沿技術(shù)<b class='flag-5'>開發(fā)</b>深度剖析

    ADS / SystemVue / 器件建模軟件——2024新功能專題研討會

    我們誠摯地邀請您參加是德科技EDA軟件2024新功能發(fā)布會,我們將重點(diǎn)介紹是德科技的EDA工具——ADS,SystemVue以及器件建模軟件在2024年發(fā)布的新功能,以幫助您了解如何通過設(shè)計(jì)左移
    的頭像 發(fā)表于 11-22 07:45 ?955次閱讀
    ADS / SystemVue / 器件建模軟件——2024<b class='flag-5'>新功能</b>專題研討會

    TDK東電化 推出新型NTC 熱敏電阻

    TDK東電化 推出新型NTC 熱敏電阻
    的頭像 發(fā)表于 11-01 15:56 ?393次閱讀
    TDK東電化 <b class='flag-5'>推出新</b>型NTC 熱敏電阻

    AT32F415C OTG新功能的使用方法

    演示AT32F415C OTG 新功能的使用方法,415C新增兩個(gè)功能,功能1:在OTGFS Device模式下,VBUS(PA9)可通過配置釋放給其它外設(shè)使用。功能1使能方法:設(shè)置寄
    發(fā)表于 10-27 07:00

    由Java改為 Kotlin過程中遇到的坑

    最近了解了下 Kotlin ,其中的很多語法糖很有意思,并且可以與 Java 無縫兼容。故嘗試在一個(gè) SpringBoot 工程上將部分類修改為 Kotlin ,下面記錄了由 Java 改為
    的頭像 發(fā)表于 09-30 16:51 ?708次閱讀
    由Java改為 <b class='flag-5'>Kotlin</b>過程中遇到的坑