2024 年的 Rust 與 Go,看完你悟了嗎?
發(fā)布時(shí)間:2024-02-01 13:56:33
Go 和 Rust 都旨在幫助你編寫正確的程序,但方式不同:例如,Go 提供了出色的內(nèi)置單元測(cè)試框架和豐富的標(biāo)準(zhǔn)庫(kù),而 Rust 則專注于利用其借用檢查機(jī)制(borrow checker)消除運(yùn)行時(shí)錯(cuò)誤。
我可以說些什么而不讓大家生氣嗎?
Rust 和 Go 哪個(gè)更好?你應(yīng)該為下一個(gè)項(xiàng)目選擇哪種語言,為什么??jī)烧咴谛阅堋⒑?jiǎn)單性、安全性、功能特性、規(guī)?;?scale)和并發(fā)性等方面如何比較?它們有什么共同點(diǎn),又有什么根本區(qū)別?讓我們通過 Rust 和 Go 的友好且公平的比較來找到答案。
1. Rust 和 Go 都很棒
首先,非常重要的是,Go 和 Rust 都是絕對(duì)優(yōu)秀的編程語言。它們現(xiàn)代、強(qiáng)大、被廣泛采用,并提供卓越的性能。
Rust 是一種低級(jí)靜態(tài)類型多范式編程語言,專注于安全性和性能 -- Gints Dreimanis[2]
然而:
Go 是一種開源編程語言,可以輕松構(gòu)建簡(jiǎn)單、可靠且高效的軟件 -- golang.org[3]
在本文中,我將嘗試簡(jiǎn)要概述我認(rèn)為的哪種場(chǎng)景下 Go 是理想的選擇,以及哪種場(chǎng)景下 Rust 可能是更好的選擇。
2. 相似之處
兩種語言的共同目標(biāo)是什么?
2.1 內(nèi)存安全
從歷史來看,軟件錯(cuò)誤和安全漏洞的最大原因之一是不安全或不正確地訪問內(nèi)存。
Rust 和 Go 以不同的方式處理這個(gè)問題,但兩者的目標(biāo)都是比其他語言在管理內(nèi)存方面更智能、更安全。
2.2 快速、緊湊的可執(zhí)行文件
它們都是編譯語言,這意味著你的程序?qū)⒈恢苯泳幾g為可執(zhí)行的機(jī)器代碼,以便你可以將程序部署為單個(gè)二進(jìn)制文件。與 Python 或 Ruby 等解釋語言相比,這也使得 Rust 和 Go 程序擁有極快的執(zhí)行速度。
2.3 通用語言
Rust 和 Go 都是功能強(qiáng)大、可擴(kuò)展的通用編程語言,你可以使用它們來開發(fā)各種現(xiàn)代軟件。兩者都擁有優(yōu)秀的標(biāo)準(zhǔn)庫(kù)和蓬勃發(fā)展的第三方生態(tài)系統(tǒng),以及強(qiáng)大的商業(yè)支持和龐大的用戶群。
2.4 務(wù)實(shí)的編程風(fēng)格
雖然 Go 和 Rust 都具有與函數(shù)式和面向?qū)ο缶幊?(OOP) 相關(guān)的功能特性,但它們都是實(shí)用語言(pragmatic languages),旨在以最合適的方式解決問題。
2.5 適于規(guī)?;拈_發(fā)
Rust 和 Go 都有一些有用的功能特性,使它們適合大規(guī)模編程,無論是大型團(tuán)隊(duì),還是大型代碼庫(kù),或兩者兼而有之。
例如,Rust 和 Go 都使用標(biāo)準(zhǔn)代碼格式化工具(Go 的 gofmt,Rust 的 rustfmt),這結(jié)束了關(guān)于括號(hào)放置位置的無用爭(zhēng)論。
兩者還具有優(yōu)秀的內(nèi)置高性能標(biāo)準(zhǔn)構(gòu)建和依賴管理工具;不再需要與復(fù)雜的第三方構(gòu)建系統(tǒng)搏斗,也不必每隔幾年學(xué)習(xí)一個(gè)新系統(tǒng)。
3. 差異
雖然 Rust 和 Go 有很多共同點(diǎn),但在某些領(lǐng)域,理性的人可能會(huì)更喜歡一種語言而不是另一種語言,以滿足項(xiàng)目的特定需求。
3.1 性能
Go 和 Rust 都非常快。然而,Go 的設(shè)計(jì)更有利于快速編譯,而 Rust 則是針對(duì)快速執(zhí)行進(jìn)行了優(yōu)化。
Rust 的運(yùn)行時(shí)性能也更加一致,因?yàn)樗皇褂美厥諜C(jī)制。另一方面,Go 的垃圾回收器減輕了程序員的一些負(fù)擔(dān),使其更容易專注于解決主要問題,而不是內(nèi)存管理的細(xì)節(jié)。
對(duì)于執(zhí)行速度勝過所有其他考慮因素的領(lǐng)域(例如游戲編程、操作系統(tǒng)內(nèi)核、Web 瀏覽器組件和實(shí)時(shí)控制系統(tǒng)),Rust 是更好的選擇。
3.2 簡(jiǎn)單
從設(shè)計(jì)上來說,Go 是一種小型語言:它的語法、關(guān)鍵字和語言結(jié)構(gòu)都非常少。你可以快速學(xué)習(xí) Go 的基礎(chǔ)知識(shí)并使用該語言提升工作效率。
這使得 Go 在時(shí)間跨度短的項(xiàng)目中或需要快速引入大量新程序員的團(tuán)隊(duì)中具有優(yōu)勢(shì),尤其是在他們相對(duì)缺乏經(jīng)驗(yàn)的情況下。
3.3 功能特性
另一方面,Rust 幾乎擁有你能想象到的編程語言的所有功能特性,還有一些你可能無法想象的功能特性。這使得它成為一種強(qiáng)大且富有表現(xiàn)力的語言,可以通過多種不同的方式來完成同一件事。
如果你是從其他語言過渡到 Rust 的,你可能可以找到你習(xí)慣的大多數(shù)功能的 Rust 等效項(xiàng)。當(dāng)大型項(xiàng)目需要從 C++或 Java 等傳統(tǒng)語言遷移時(shí),這給 Rust 帶來了優(yōu)勢(shì)。
3.4 并發(fā)
與大多數(shù)語言不同,Go 語言的設(shè)計(jì)內(nèi)置了對(duì)并發(fā)編程的支持,例如 goroutine(線程的輕量級(jí)版本)和通道(在并發(fā)任務(wù)之間通信數(shù)據(jù)的安全有效的方法)。
這些使得 Go 成為網(wǎng)絡(luò)服務(wù)器和微服務(wù)等大規(guī)模并發(fā)應(yīng)用程序的完美選擇。
3.5 安全
Rust 經(jīng)過精心設(shè)計(jì),以確保程序員無法做一些他們不想做的不安全的事情,例如覆蓋共享變量。編譯器要求你明確在程序的不同部分之間共享數(shù)據(jù)的方式,并且可以檢測(cè)許多常見的錯(cuò)誤和 bug。
因此,所謂的“與借用檢查器(borrow checker)戰(zhàn)斗”是新 Rust 程序員的常見抱怨。用安全的 Rust 代碼實(shí)現(xiàn)程序通常意味著從根本上重新思考其設(shè)計(jì),這可能會(huì)令人沮喪,但當(dāng)可靠性是你的首要任務(wù)時(shí),這樣做的好處是值得的。
3.6 規(guī)?;?scale)
Go 旨在讓你輕松擴(kuò)展項(xiàng)目和開發(fā)團(tuán)隊(duì)。它的極簡(jiǎn)設(shè)計(jì)帶來了一定的一致性,并且明確定義的標(biāo)準(zhǔn)風(fēng)格的存在意味著任何 Go 程序員都可以相對(duì)快速地閱讀和理解新的代碼庫(kù)。
當(dāng)談到大型軟件開發(fā)時(shí),清晰勝于聰明。對(duì)于大型組織,尤其是許多分布式團(tuán)隊(duì)來說,Go 是一個(gè)不錯(cuò)的選擇。其快速構(gòu)建時(shí)間也有利于快速測(cè)試和部署。
4. 權(quán)衡取舍
Rust 和 Go 的設(shè)計(jì)團(tuán)隊(duì)做出了一些截然不同的選擇,所以讓我們看看這些權(quán)衡取舍使這兩種語言彼此截然不同的一些領(lǐng)域。
4.1 垃圾回收
一般來說,具有垃圾回收和自動(dòng)內(nèi)存管理功能的語言(如 Go)可以快速輕松地開發(fā)可靠、高效的程序,對(duì)于某些人來說這是最重要的。
但是垃圾回收由于其性能開銷和停止世界(Stop-The-World)的暫停,可能會(huì)使程序在運(yùn)行時(shí)的行為變得不可預(yù)測(cè),有些人發(fā)現(xiàn)這種不一致是不可接受的。
程序員必須明確負(fù)責(zé)分配和釋放每個(gè)字節(jié)內(nèi)存的語言(例如 Rust)更適合實(shí)時(shí)或超高性能應(yīng)用程序。
4.2 抽象
計(jì)算機(jī)編程的歷史是一個(gè)日益復(fù)雜的抽象的故事,它讓程序員可以解決問題,而不必過多擔(dān)心底層機(jī)器的實(shí)際工作方式。
這使得程序更容易編寫并且可能更可移植。但對(duì)于許多程序來說,訪問硬件以及精確控制程序的執(zhí)行方式更為重要。
Rust 的目標(biāo)是讓程序員“更接近金屬”,擁有更多的控制權(quán),而 Go 抽象了架構(gòu)細(xì)節(jié),讓程序員更接近問題。
4.3 速度
Rust 進(jìn)行了許多設(shè)計(jì)權(quán)衡,以實(shí)現(xiàn)最佳的執(zhí)行速度。相比之下,Go 更關(guān)心簡(jiǎn)單性,并且愿意為此犧牲一些(運(yùn)行時(shí))性能。
在這一點(diǎn)上你是喜歡 Rust 還是 Go 取決于你是愿意花更多的時(shí)間等待程序構(gòu)建,還是等待程序運(yùn)行。
4.4 正確性
Go 和 Rust 都旨在幫助你編寫正確的程序,但方式不同:例如,Go 提供了出色的內(nèi)置單元測(cè)試框架和豐富的標(biāo)準(zhǔn)庫(kù),而 Rust 則專注于利用其借用檢查機(jī)制(borrow checker)消除運(yùn)行時(shí)錯(cuò)誤。
公平地說,用 Go 編寫給定的程序更容易,但結(jié)果可能比 Rust 版本更容易包含錯(cuò)誤。Rust 對(duì)程序員施加了紀(jì)律約束,但 Go 讓程序員選擇他們想要對(duì)特定項(xiàng)目采取的紀(jì)律程度。
5. 結(jié)論
我希望這篇文章能讓你相信 Rust 和 Go 都值得你認(rèn)真考慮。你應(yīng)該拒絕這種錯(cuò)誤的困境:你只能學(xué)習(xí)其中之一。事實(shí)上,你了解的語言越多,你作為軟件開發(fā)人員的價(jià)值就越高。
你學(xué)習(xí)的每一種新語言都會(huì)給你思考問題的新方法,這只能是一件好事。任何軟件項(xiàng)目的質(zhì)量和成功最重要的因素不是語言的選擇,而是程序員的技能。
當(dāng)使用最適合你的語言時(shí),你變得最熟練,并且你也能享受到最多的編程帶給你的樂趣。因此,如果問題是“我應(yīng)該學(xué)習(xí) Rust 或 Go 嗎?”,唯一正確的答案是“是的”。
技術(shù)前沿拓展
前端開發(fā),你的認(rèn)知不能僅局限于技術(shù)內(nèi),需要發(fā)散思維了解技術(shù)圈的前沿知識(shí)。細(xì)心的人會(huì)發(fā)現(xiàn),開發(fā)內(nèi)部工具的過程中,大量的頁(yè)面、場(chǎng)景、組件等在不斷重復(fù),這種重復(fù)造輪子的工作,浪費(fèi)工程師的大量時(shí)間。
介紹一款程序員都應(yīng)該知道的軟件JNPF快速開發(fā)平臺(tái),很多人都嘗試用過它,它是功能的集大成者,任何信息化系統(tǒng)都可以基于它開發(fā)出來。
這是一個(gè)基于 Java Boot/.Net Core 構(gòu)建的簡(jiǎn)單、跨平臺(tái)快速開發(fā)框架。前后端封裝了上千個(gè)常用類,方便擴(kuò)展;集成了代碼生成器,支持前后端業(yè)務(wù)代碼生成,實(shí)現(xiàn)快速開發(fā),提升工作效率;框架集成了表單、報(bào)表、圖表、大屏等各種常用的 Demo 方便直接使用;后端框架支持 Vue2、Vue3。
以上為本次所有分享內(nèi)容
- 上一篇:Linux 設(shè)置定時(shí)任務(wù)常用的三種方法
- 下一篇:沒有了