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

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

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

用Rust和C++代碼編譯時(shí)間同樣糟糕嗎?

jf_wN0SrCdH ? 來源:覺學(xué)社 ? 2023-01-16 11:58 ? 次閱讀

Rust 官方正在討論為 Rust 提供 interoperable_abi features gate

interoperable_abi[1] 意味著提供一個(gè)新的 Rust ABI extern "interop" 和 repr(interop) ,用于實(shí)現(xiàn)有安全數(shù)據(jù) 類型的高級編程語言之間的互操作性。

13ed3214-9430-11ed-bfe3-dac502259ad0.png

動機(jī)摘要:

目前 Rust ABI 并不穩(wěn)定,多語言交互只能通過 C-ABI 來進(jìn)行。但是這限制了在 ABI 之間使用更高級的安全類型。可互操作的 ABI 將定義一種標(biāo)準(zhǔn)方法來跨高級語言進(jìn)行調(diào)用,傳遞高級數(shù)據(jù)類型,而不需要將其降級為 C-ABI。該 ABI 將與任何提供C 兼容 FFI 的語言(包括 C本身),并且語言還可以為可互操作的 ABI 添加特定的更高級別的支持??苫ゲ僮鞯?ABI 旨在成為靜態(tài)和動態(tài)形式的編譯庫(包括系統(tǒng)庫)的合理默認(rèn)值。

可互操作的 ABI 將是 C ABI 的嚴(yán)格超集。

可互操作 ABI 不支持的內(nèi)容摘要:

可互操作的 ABI 并不旨在支持整個(gè)Rust 標(biāo)準(zhǔn)庫.

可互操作的 ABI 不會旨在支持復(fù)雜的生命周期處理

可互操作的 ABI(至少在第一個(gè)版本中)不會以源代碼或編譯形式提供接口描述語言(IDL)

可互操作的 ABI 的目的不是在不同語言的表示之間提供“翻譯”

可互操作的 ABI 不能支持任意的編譯時(shí)泛型函數(shù)

GCC-rs 項(xiàng)目在 2022 年取得了很大進(jìn)展

gccrs是一個(gè)旨在為 GNU Compiler Collection 帶來對 Rust編程語言的支持的項(xiàng)目。其目標(biāo)是從頭開始為 Rust 編程語言編寫一個(gè)新的編譯器前端,將該前端集成到 GCC 中,使其作為一種語言與 C、C++、Ada、D、Go 一起使用。

該項(xiàng)目最初于 2014 年啟動。當(dāng)時(shí),Rust 尚未實(shí)現(xiàn)穩(wěn)定版本(Rust 1.0 于 2015 年 5 月發(fā)布),對于單個(gè)開發(fā)人員來說很難跟上高強(qiáng)度的變化。2019年又開始努力,此后一直在穩(wěn)步進(jìn)行。

2020 年,菲利普·赫倫 ( Philip Herron )開始獲得資金支持,隨后他得以開始全職從事該項(xiàng)目。此贊助來自 Open Source Security公司。

Philip 受雇于 Embecosm 并從他們的管理中受益,并得到 GCC 指導(dǎo)委員會的支持。2022 年,在將近一年半的單飛之后,Philip 加入了另一位由 Open Source Security 公司資助的全職工程師 Arthur Cohen ,也受雇于 Embecosm?,F(xiàn)在有兩名工程師每周為該項(xiàng)目投入 40 小時(shí)。

2022 年發(fā)生的最引人注目的事件是將 gccrs 合并到 GCC,gccrs 將在 2023 年 4 月發(fā)布的 GCC 13.1 版本中可用。

更多內(nèi)容參考 gccrs 2022 年報(bào)[2]

P.S 與 gccrs 對應(yīng)的是另一個(gè)項(xiàng)目 rustc_codegen_gcc。它是作為 Rust 編譯器 GCC 后端,目前也正在積極開發(fā)中,感興趣可以關(guān)注rustc_codegen_gcc:進(jìn)度報(bào)告#19[3]。

用 Rust 和 C++ 代碼編譯時(shí)間同樣糟糕嗎?

原文[4]作者寫道:

C++ 因其緩慢的構(gòu)建時(shí)間而臭名昭著?!拔业拇a正在編譯”是編程世界中的一個(gè)梗,而 C++ 讓這個(gè)笑話流傳開來。

像 Google Chromium 這樣的項(xiàng)目 在全新硬件上構(gòu)建需要一個(gè)小時(shí),在舊硬件上構(gòu)建需要 6 小時(shí)。即使有數(shù)千美元的云計(jì)算能力,Chromium 構(gòu)建時(shí)間仍然在六分鐘左右。這是我完全不能接受的。人怎么可以每天這樣工作?

作者也聽說,Rust 也面臨相同的問題,但他有實(shí)證精神,親自動手證明一下 Rust 是不是和 Cpp 一樣很慢。

這是他的計(jì)劃:

查找開源 C++ 項(xiàng)目。

從項(xiàng)目中提取一部分為迷你項(xiàng)目中。

將 C++ 迷你項(xiàng)目的代碼逐行重寫為 Rust。

優(yōu)化 C++ 項(xiàng)目和 Rust 項(xiàng)目的構(gòu)建工具鏈。

比較兩個(gè)項(xiàng)目之間的編譯+測試時(shí)間。

經(jīng)過這樣的測試,作者得出最終結(jié)論:

編譯時(shí)間是 Rust 的問題嗎?是的。有一些提示和技巧可以加快構(gòu)建速度,但作者沒有找到神奇的數(shù)量級改進(jìn),否則作者將很高興使用 Rust 進(jìn)行開發(fā)。

Rust 的構(gòu)建時(shí)間和 C++ 一樣糟糕嗎?是的。對于更大的項(xiàng)目,Rust 的開發(fā)編譯時(shí)間比 C++ 更短,至少作者的代碼風(fēng)格是這樣。

對于完整構(gòu)建,C++ 構(gòu)建花費(fèi)的時(shí)間與 Rust 相比,大致相同(17k SLOC)或花費(fèi)更少的時(shí)間(100k+ SLOC),而不是更長。

對于增量構(gòu)建,與 C++ 相比,Rust 構(gòu)建有時(shí)更短,有時(shí)更長(17k SLOC)或更長(100k+ SLOC),但并不總是更長。

很欣賞 Rust 的工具鏈(尤其是 Cargo、rustup 和 miri)。

應(yīng)用實(shí)踐

Gama 發(fā)射的太陽帆宇宙飛船中使用了 Rust

Gama[5] 將發(fā)射太陽帆宇宙飛船,并且是公開將 Rust 送入太空的公司之一。提供軟件服務(wù)的應(yīng)該是這家公司:Tweedegolf[6] ,該公司也是 Rust 基金會銀牌會員。他們的開源倉庫[7]里有一個(gè) Rust 實(shí)現(xiàn)的 PTP (精確時(shí)間協(xié)議) 庫,這個(gè)PTP一般用在衛(wèi)星的時(shí)間源,比NTP更精確。但這個(gè)是 PoC 實(shí)現(xiàn),不知道這次發(fā)射的飛船上有沒有用。從另外的項(xiàng)目 嵌入式開發(fā)板 pcf85063a (一般用于計(jì)時(shí)鬧鐘)rust 驅(qū)動來看,這次上天的 Rust 程序很可能和精確計(jì)時(shí)相關(guān)。

Gama 太陽帆的衛(wèi)星于 2023 年 1 月 3 日由 SpaceX 獵鷹 9 號成功送入軌道[8]。

生態(tài)看點(diǎn)

svix-webhooks:企業(yè)級 Webhooks 服務(wù)

svix-webhooks[9] 是基于 Rust 實(shí)現(xiàn)的企業(yè)級 Webhooks 服務(wù)器。Svix 使開發(fā)人員可以輕松發(fā)送 webhook。開發(fā)人員進(jìn)行一次 API 調(diào)用,Svix 負(fù)責(zé)可交付性、重試、安全性等。

turmoil:開發(fā)和測試分布式系統(tǒng)的框架

Tokio 發(fā)布了[10]用于開發(fā)和測試分布式系統(tǒng)的框架 turmoil[11] 的初始版本。

測試分布式系統(tǒng)很難。不確定性無處不在(網(wǎng)絡(luò)、時(shí)間、線程等),使得難以實(shí)現(xiàn)可重現(xiàn)的結(jié)果。由于部署,開發(fā)周期很長。所有這些因素都會減慢開發(fā)速度,并且難以確保系統(tǒng)的正確性。turmoil力求通過模擬主機(jī)、時(shí)間和網(wǎng)絡(luò)來解決這些問題。這允許整個(gè)分布式系統(tǒng)在單個(gè)線程的單個(gè)進(jìn)程中運(yùn)行,從而實(shí)現(xiàn)確定性執(zhí)行。

cargo-sandbox 發(fā)布

cargo-sandbox[12] 打算成為 cargo 的一個(gè)近乎直接的替代品。關(guān)鍵的區(qū)別在于,cargo-sandbox 在 docker 容器中運(yùn)行相關(guān)命令,目的是將潛在的惡意代碼與主機(jī)環(huán)境的隔離開來(關(guān)于威脅模型的更多細(xì)節(jié),見README)。其目標(biāo)是盡可能地接近 "100%"的兼容原版 cargo,并獲得最順暢的體驗(yàn)。

Rust 中的深度學(xué)習(xí):Burn 0.4.0 發(fā)布以及 2023 年的規(guī)劃

Rust 深度學(xué)習(xí)框架Burn[13] 0.4 完成了后端重構(gòu),除此之外,還實(shí)現(xiàn)了很多新的功能,如ADAM優(yōu)化器、轉(zhuǎn)化器模塊等。下一個(gè)重點(diǎn)將是增加視覺相關(guān)的模塊,如卷積和池化層。

shura-一個(gè)安全的2D 游戲引擎,易于創(chuàng)建易于管理的游戲

shura[14] 是rust編寫的一個(gè)安全,快速并且跨平臺的游戲框架。shura使用一個(gè)2D組件系統(tǒng)、場景管理和group系統(tǒng)幫你管理一個(gè)大型游戲。

shura主要的目標(biāo)是,你的游戲邏輯可以分別放在不同的組件、group和場景中。

rumqtt: 構(gòu)建 mqtt 的 Rust 生態(tài)

rumqtt[15] 是一組用 rust-lang 編寫的開源庫,用于實(shí)現(xiàn) MQTT 標(biāo)準(zhǔn),同時(shí)力求簡單、健壯和高性能。

rumqtt 是 Bytebeam 物聯(lián)網(wǎng)咨詢公司開源的 MQTT 代理。rumqtt 目前版本已經(jīng)發(fā)布到了 R19 版,并未按語義化版本來發(fā)布。

目前發(fā)布了 R19 新版本:

新的版本提升了性能和可靠性(可以支持 多達(dá)10,000 多個(gè) MQTT 客戶端,使用 mqttwrk[16] 進(jìn)行基準(zhǔn)測試)

添加了一個(gè)用于測試 rumqttd 的公共服務(wù)器

添加了 Prometheus 集成和其他優(yōu)化更改

加了對存儲支持的持久性的實(shí)驗(yàn)性支持,以確保消息的零數(shù)據(jù)丟失

rumqtt 在 2023 年初推出對 MQTT v5 的支持。






審核編輯:劉清

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

    關(guān)注

    0

    文章

    143

    瀏覽量

    17438
  • gcc編譯器
    +關(guān)注

    關(guān)注

    0

    文章

    78

    瀏覽量

    3338
  • rust語言
    +關(guān)注

    關(guān)注

    0

    文章

    57

    瀏覽量

    2994

原文標(biāo)題:【2023 Week-1】Rust視界周刊 | 用 Rust 和 C++ 代碼編譯時(shí)間同樣糟糕嗎?

文章出處:【微信號:Rust語言中文社區(qū),微信公眾號:Rust語言中文社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    鴻蒙OpenHarmony開發(fā)板解析:【Rust模塊配置規(guī)則和指導(dǎo)】

    C/C++代碼和提升編譯速度,使用了GN + Ninja的編譯構(gòu)建系統(tǒng)。GN的構(gòu)建語言簡潔易讀,Ninja的匯編級
    的頭像 發(fā)表于 05-10 11:32 ?1166次閱讀
    鴻蒙OpenHarmony開發(fā)板解析:【<b class='flag-5'>Rust</b>模塊配置規(guī)則和指導(dǎo)】

    如何為Arm編譯Cc++代碼

    編寫CC++應(yīng)用程序時(shí),需要使用編譯器工具鏈將其編譯為機(jī)器代碼。然后,您可以在基于Arm的處理器上運(yùn)行此
    發(fā)表于 08-02 17:28

    C++的G代碼解析算法研究

    進(jìn)行編寫解析算法,把G 代碼作為一個(gè)對象,類機(jī)制實(shí)現(xiàn)其解析功能,并使用GCC 作為其編譯器,提高編譯效率??芍苯討?yīng)用嵌入式,脫離PC+運(yùn)動控制卡的限制。通過實(shí)驗(yàn)的測試,以ARM 開發(fā)
    發(fā)表于 07-21 16:36 ?0次下載

    高級C/C++編譯技術(shù)

    C/C++編譯技術(shù)
    發(fā)表于 12-04 17:19 ?18次下載

    微軟開始嘗試使用Rust代替C/C++,介紹這些運(yùn)用Rust的產(chǎn)品

    微軟擁有世界上最大的C/C++代碼庫之一。從Windows、Office到Azure云,微軟的所有核心產(chǎn)品都在該代碼庫上運(yùn)行。但因?yàn)?b class='flag-5'>C++不
    的頭像 發(fā)表于 09-03 10:09 ?4080次閱讀

    VScode編譯器如何配置C/C++編譯環(huán)境

    昨天有伙伴私信我,為什么我C語言寫的hello world幾行代碼,在編譯器里面報(bào)錯(cuò)了呢?
    的頭像 發(fā)表于 03-16 08:38 ?5534次閱讀

    qtC++寫的2048小游戲源代碼

    qtC++寫的2048小游戲源代碼
    發(fā)表于 09-27 11:48 ?1次下載

    Rust在虛幻引擎5中的使用

    前段時(shí)間,研究了一套 Rust 接入 Maya Plugin 的玩法,主要原理還是使用 C ABI 去交互。那我想著 UE 是使用 C++ 寫的,肯定也可以使用
    的頭像 發(fā)表于 12-21 11:05 ?5809次閱讀

    Chromium正式開始支持Rust

    ? Chromium 正式開始支持 Rust 目前的支持只是第一階段,在C++代碼中使用Rust寫的第三方庫(編譯成.so)。估計(jì)明年Chr
    的頭像 發(fā)表于 01-14 10:04 ?906次閱讀

    RustC++哪個(gè)更好入門

    作為一門系統(tǒng)編程語言,Rust 一直致力于解決高并發(fā)和高安全性系統(tǒng)等問題。和老牌的 C++ 相比,Rust 的性能也毫不遜色。但曾幾何時(shí),因?yàn)樯鲜蛛y、用戶量少、社區(qū)不活躍等諸如問題讓想要入門的開發(fā)者感到迷茫,如今新的一年已經(jīng)開始
    的頭像 發(fā)表于 03-17 14:45 ?1857次閱讀

    Windows 11初嘗Rust,36000行內(nèi)核代碼已重寫!

    。當(dāng)下,DWriteCore 包含了大約 152,000 行 Rust 代碼和 96,000 行 C++ 代碼。
    的頭像 發(fā)表于 05-19 16:39 ?958次閱讀
    Windows 11初嘗<b class='flag-5'>Rust</b>,36000行內(nèi)核<b class='flag-5'>代碼</b>已重寫!

    取代C++!微軟Rust改寫的Win11內(nèi)核來了

    按照微軟此前介紹,Rust 語言的優(yōu)勢在于極高的內(nèi)存安全性,原來內(nèi)核中大量的不安全的子例程在改寫后消失不見。同時(shí),Rust 代碼簡潔高效,移植后 Office 應(yīng)用沒有任何性能損失,甚至部分場景比
    的頭像 發(fā)表于 05-19 16:58 ?1367次閱讀
    取代<b class='flag-5'>C++</b>!微軟<b class='flag-5'>用</b><b class='flag-5'>Rust</b>改寫的Win11內(nèi)核來了

    使用C++編寫通用庫并在 Rust 中使用它 (WASI)

    的速度運(yùn)行代碼。它不特定于網(wǎng)絡(luò),也可以在其他平臺上運(yùn)行。WebAssembly 代碼可以從各種編程語言編譯而來,例如 CC++、
    的頭像 發(fā)表于 06-16 10:03 ?979次閱讀
    使用<b class='flag-5'>C++</b>編寫通用庫并在 <b class='flag-5'>Rust</b> 中使用它 (WASI)

    谷歌捐款100萬美元給Rust基金會,以增強(qiáng)C++Rust的交互性

    如今,谷歌多項(xiàng)核心業(yè)務(wù)仍以 C++為主要編程語言,雖然無法直接使用Rust替代現(xiàn)有的C++程序,但谷歌依然選擇支持Rust基金會的“Interop Initiative”計(jì)劃,幫助那些
    的頭像 發(fā)表于 02-19 15:41 ?549次閱讀

    [鴻蒙]OpenHarmony4.0的Rust開發(fā)

    。 OpenHarmony 為了集成 C/C++ 代碼和提升編譯速度,使用了 GN + Ninja 的編譯構(gòu)建系統(tǒng)。GN 的構(gòu)建語言簡潔易讀
    的頭像 發(fā)表于 02-26 17:28 ?753次閱讀
    [鴻蒙]OpenHarmony4.0的<b class='flag-5'>Rust</b>開發(fā)