比特幣交易所 比特幣交易所
Ctrl+D 比特幣交易所
ads

開發者說:為什么我選擇 Rust?_UST

Author:

Time:1900/1/1 0:00:00

作者:DmitriyKashitsyn@Parity?Technologies

翻譯:孫元超@CdotNetwork

來源:https://www.parity.io/why-rust/

WhyRust?

編程很難。

不是因為我們人體本身構造復雜,而是因為我們都只是人類。我們的注意力持續時間有限,記憶也不是永久的——換句話說,我們往往會犯錯。電腦和軟件無處不在:在太空中,天上,地面,佩戴在身上,甚至在我們的身體里。每天都有越來越多的系統實現自動化,越來越多的生命依賴于軟件及其質量,航空電子設備,自動駕駛汽車,核電站,交通控制系統,植入式心臟起搏器。這些系統中的bug幾乎總是危及人類的生命。

“程序正確性是通過測試來檢驗的”和“程序正確性是經過邏輯驗證的”之間存在著巨大的差異。不幸的是,即使我們對代碼的每一行都進行了測試,我們仍然不能確保它是正確的。然而,擁有一個形式系統來證明我們的代碼是正確的(至少在某些方面是正確的)則是另一回事了。

Rust的方式

「Rust作為一種編程語言」的不同之處,不是因為它的花哨語法或受歡迎的社區,而是因為人們在使用它編寫程序時能獲得信心。Rust非常嚴格并且追究細節的編譯器會檢查你使用的每個變量和引用的每個內存地址。它可能看起來會妨礙你編寫高效且富有表現力的代碼,但令人驚訝的是,恰恰相反:編寫一個有效且地道的Rust程序實際上比編寫一個有潛在危險的程序更容易。在后一種情況下,你將與編譯器發生沖突,因為你嘗試的幾乎所有操作都會導致內存安全問題。

Coinbase公布第一輪加密社區基金開發者資助名單:Coinbase公布了首批獲得加密社區基金開發者資助的機構,前兩位開發者Jo?o Barbosa和化名開發者0xB10C由基金顧問委員會選出。據悉,該基金于去年10月首次宣布成立,旨在支持比特幣開發者在加密貨幣底層技術項目上的工作。(Coindesk)[2020/12/23 16:11:57]

上圖右側部分顯示了并發性和內存安全相關的問題,這些問題根源上不可能發生在常規Rust代碼中。所以只需要換成Rust,他們就可以杜絕這段時間內大約一半的bug。同時,緩沖區溢出是其中最危險的bug,因為它們常常導致「密鑰泄露」、拒絕服務和遠程代碼執行漏洞。

上圖還表明,“一個人只需要知道如何編寫C”和“只需要把底層的東西留給專業人士”這樣的想法是不夠的。Linux內核是由行業中最優秀的5%的人編寫的,然而,內存bug這位老朋友一年又一年的給我們貢獻著CVE。

當然,與kernel中數百萬行正常工作的代碼相比,這50個bug根本算不了什么。但是之前說過的生死攸關的問題,還記得嗎?當我們談到關鍵系統時,即使是最小的錯誤也可能導致災難性的后果。還沒提及這50個只是被發現了的bug。誰知道還有多少沒被發現呢?如果使用Rust,我們會事先知道這些問題。

Gemini宣布與開源基金Brink合作資助比特幣開發者社區:11月25日,加密貨幣交易所Gemini官方宣布與開源基金Brink合作,支持和資助比特幣開源開發者社區。11月24日,比特幣開源開發者John Newbery宣布成立開源基金Brink。而在該基金中,John Newbery和另一位開發者Wences Casares將提供組織資助,而包含Gemini和Square在內的機構則向兩位開發者提供資助。[2020/11/25 22:02:09]

Rust有多快?

你可能會想:當然,Rust可能提供了這么多東西來杜絕這些隱患,但是要花多少代價呢?通常,在現代編程語言中的內存安全需要負擔垃圾回收器的開銷。并發問題通常通過使用特殊的同步原語鎖定所有受影響的數據結構和執行路徑來解決。

但對于Rust就不是這樣了。它的強大來自于巧妙的類型系統,可以在編譯時就解決所有這些問題。「TypeSystem的設計」同時防止了內存問題和數據競爭問題。

就像在C++中一樣,你可以只使用你需要的東西。例如,在Rust中,你只在絕對需要時才使用互斥鎖。而且,Rust編譯器會需要的位置迫使你使用它,所以永遠不會忘記。所有這些基本上都是零成本的。由于大多數檢查都是在編譯時執行的,因此編譯后的程序集與C或C++編譯器生成的程序集沒有太大區別。

由于這個原因,Rust現在在「嵌入式電子」、「物聯網」,甚至「操作系統開發」領域都非常有前景,而這些領域以前都是由C語言主導的,因為需要很高的控制要求、資源和性能也有嚴格的限制。

BCH開發者發文支持IFP 稱IFP并非強制稅收而是手續費:在近期BCH DAA算法引發社區熱議后,BCH此前已宣告失敗的BCH基礎設施融資計劃(IFP)又再度引起關注。8月10日,BCH軟件開發者Tobias Ruck發文《盡管社區討厭IFP,為什么我選擇支持IFP,以及如何解決這個問題》闡述其支持IFP計劃的理由。Tobias Ruck在文中表示,很多人將BCH基礎設施融資計劃(IFP)稱為一項稅收政策,但實際上,這只是一個形象的比喻而已。IFP并非一種強制的稅收政策,稱為稅收有一種強制的剝削意味。相反應該把它叫做手續費更為合適。因為用戶發起交易,礦工進行打包驗證、故而用戶向礦工支付交易費;而礦工需要基礎設施來運行網絡,故而礦工向開發人員支付其基礎設施費用,用以開發人員進行開發。

而針對具體如何解決IFP問題,Tobias Ruck提出需要注意三點:1.需要建立某種形式的BCH宣言;2.IFP白名單必須滿足一組明確條件;3.需要設立一組獨立的審核員。審核員可以是社區志愿者,也可以是第三方資助者。

注:BCH基礎設施融資計劃(IFP)是指將礦工挖礦的收益,按照固定百分比發送到指定的地址列表,以作為BCH基礎設施開發資金[2020/8/10]

Rust的最新版本甚至在用戶空間引入了SIMD支持。以前,由于API穩定性的限制,它只能在nightly版本中使用。現在,你可以通過直接使用向量指令或使用「便捷的包裝庫」來釋放硬件的全部潛力。而且,即使你不打算這樣做,編譯器仍然會在可能的情況下自動向量化循環語句和其他東西,在許多情況下,可以達到手工編寫向量指令代碼的性能水平。

以太坊開發者Virgil Griffith尋求將審判地點移出紐約南區法院:金色財經報道,根據7月23日的一份報告,因目前因缺乏審判地點,以太坊基金會前特別項目負責人Virgil Griffith正尋求將其“朝鮮行”相關案件轉出紐約南區法院。此外, Griffith還尋求法院允許其使用互聯網。據此前消息,去年11月29日,紐約南區美國檢察官辦公室和聯邦調查局宣布,已逮捕并指控以太坊開發者Virgil Griffith違反美國制裁法。[2020/7/25]

我們為什么使用Rust

ParityTechnologies使用Rust也是出于同樣的原因。因為它讓我們可以毫無畏懼地編寫復雜而且高性能的軟件。我們可以自由地進行實驗,因為我們確信Rust將為我們提供支撐。無論是實現一個簡單的命令行實用程序還是一個多線程龐然大物,它都沒有什么區別。Rust確保我們的程序不存在未定義的行為、數據競爭或任何內存安全問題。更不用說,Rust「非常快」,編寫起來很有趣,易于閱讀,而且幾乎沒有運行時。

內存bug之所以難以發現,是因為你不能輕松地編寫測試來捕獲它。如果你在beta測試期間沒有發現bug,那么它可能會在代碼中存在數年,就像定時炸彈等待著爆炸的那一刻。當然,也有像「Valgrind」這樣的工具可以幫助捕獲這些bug。但即使是Valgrind,如果問題發生時不是執行在調試模式下,或者執行時沒有表現為內存方面的問題,它也不會捕獲到bug。

聲音 | 比特幣核心開發者:比特幣要求你對自己的財富負責:比特幣核心開發者Jimmy?Song今日發推稱,提示:1. 備份種子;2. 對你的密碼負責。比特幣要求你對自己的財富負責。如果你還沒準備好,那就不要買。[2020/1/20]

因此,通過使用Rust,我們消除了最復雜、最不可預測的一類錯誤。

測試的作用

當然,內存安全問題只是所有問題的一部分。例如,我們可以編寫一個函數對它的整型參數求和,但是它只隨意返回了一個常數。或者我們寫了一個隨機數生成器卻生成的是可預測的值。這種行為并沒有違反Rust的內存安全保證,但顯然是不正確的。

這就是測試的用武之地。測試允許我們檢查編譯器無法理解的不變量因素。基本上,我們需要確保相應的測試覆蓋了返回的每個結果和程序中做出決策的每個點。在上面的例子中,測試必須檢查函數是否確實返回其參數的和,還有產生的隨機數是否足夠隨機。

在某種意義上,邏輯錯誤更容易處理。從定義上講,它們與程序員編寫程序時考慮的領域是相同的(而內存bug則不在其中)。

幸運的是,我們知道如何處理這些bug。在過去的幾十年里,程序員和計算機科學家創造了一套方法和工具,通過使用這些方法和工具,我們可以減少邏輯錯誤的數量,并將它們保持在最小。

數學的力量

在最嚴格和復雜的途徑中,程序正確性是被驗證出的,而不是通過檢驗。像「Iris」和「Coq」這樣的語言可以用來證明整個程序的正確性。不是像測試一樣檢查一些輸入的有效性,而是把它被當作一個數學定理一樣證明,一次和所有可能的輸入和每個可能的場景。只有通過構造這樣的證明,你才能獲得程序是正確的信心(只要你的規范和理解是正確的)。

基本上,Rust做的是相同的事情,但是只針對一些限定的特殊問題,比如并發性和內存安全性。實際上,它使用邏輯來證明你的程序在這些方面是正確的。想想看,僅僅通過編寫常規的Rust代碼,你就可能擁有與每次編譯項目時讓一組數學家研究某個定理相同的信心水平。

不幸的是,證明系統的每個部分都是如此是十分復雜和耗時的,以至于通常只對軟件的最關鍵部分進行驗證,比如操作系統內核、密碼算法,在某些情況下,還有語言的標準庫。

在很長一段時間內,像Haskell這樣的函數式編程語言的一個殺手級特性就是可以形式證明代碼,而傳統的命令式編程語言由于廣泛使用了共享可變性、不安全的指針運算和無法控制的副作用,仍然無法應用形式證明。但是Rust可以改變這一點,盡管它是一種命令式語言,但它已然「在進行形式化證明的路上」。

「來自RustBelt項目的RalfJung等人」已經發表了一些「論文」,證明了Rust語言聲明的基本不變量確實包含在標準庫的一些重要原語中。

問題是,出于性能原因,Rust標準庫包含許多潛在的unsafe代碼和raw指針運算。

為了證明標準庫的正確性,RalfJung和同事設計了一個叫做λrust的方法可以不收安全約束的使用分離的邏輯和他們自己的演算過程。通過這種演算,他們試圖證明標準庫原語和容器的工作方式符合預期,并且它們沒有違反Rust的基本不變量。作為副產品,他們甚至在同步原語,比如「MutexGuard」和「Arc」中發現了一些bug。

但這項工作遠未完成。正如作者所指出的:

我們離證明libstd中的所有東西還差很遠。那將需要比我們能召集的更多的人力。相反,我們關注的是那些看起來最有趣和對類型系統最有壓力的libstd原語。這主要是圍繞內部的可變性。因此,我們已經驗證了Cell、RefCell、Rc、Mutex、RwLock、Arc以及本文博客文章中(https://www.ralfj.de/blog/2017/07/08/rustbelt.html)。

我們希望有一天我們能夠為ParityTechnologies編寫的代碼帶來同樣級別的正確性證明。結合它的控制水平、捕獲內存問題和并發問題的能力,Rust正在成為最先進的主流通用語言之一,可以成功地用于編寫健壯、安全和高效的程序。

Rust作為一種編程語言:https://www.rust-lang.org/en-US/

密鑰泄露:http://heartbleed.com/

TypeSystem:https://blog.rust-lang.org/2015/04/10/Fearless-Concurrency.html

嵌入式電子:http://blog.japaric.io/

物聯網:https://www.tockos.org/

操作系統開發:https://wiki.osdev.org/Rust

庫:https://github.com/AdamNiederer/faster

Faster:https://benchmarksgame-team.pages.debian.net/benchmarksgame/faster/rust.html

Iris:http://iris-project.org

Coq:https://coq.inria.fr

Formalizing:https://www.ralfj.de/blog/2015/10/12/formalizing-rust.html

RalfJung:http://plv.mpi-sws.org/rustbelt/)

RalfJung相關論文:https://people.mpi-sws.org/~dreyer/papers/rustbelt/paper.pdf

MutexGuard:https://www.ralfj.de/blog/2017/06/09/mutexguard-sync.html

Arc:https://www.ralfj.de/blog/2018/07/13/arc-synchronization.html

Tags:USTHTTTPSBCHUSTCCHTTtps幣行情BCHB

火幣交易所
龍白滔推薦 | 數字世界中的歐洲金融主權_ACP

文/法國央行第一副行長DenisBeau第一副行長DenisBeau先生在巴黎“科技金融協會”會議上的講話.

1900/1/1 0:00:00
探索 ETH 2.0:跨片通信是如何處理的?_區塊鏈

來源:Adiasg.me 翻譯:頭等倉 編者注:原標題為《探索ETH2.0的跨片通信》隨著Eth2.0的階段深入,研究重點正在轉移到階段2:狀態執行.

1900/1/1 0:00:00
區塊鏈入門|Filecoin上線測試網,IPFS的時代要來臨了?_FIL

作者|李火華 出品|白話區塊鏈 北京時間昨天凌晨1點55分左右,推遲了一年多時間的Filecoin項目終于啟動了測試網.

1900/1/1 0:00:00
我國法律體系中對STO的監管要求——法律條文分析_數字貨幣

來源:未央網 作者:JansenMa 隨著區塊鏈分布記賬、量子計算等技術的發展,可對法律意義上的一切物權、債權、知識產權、股權及其他財產性權利等底層資產進行確權,形成證券型通證.

1900/1/1 0:00:00
科普 | 神奇了,數字貨幣怎么能夠離線支付_ALI

作者:陳利人 來源:待字閨中 常看到數字貨幣的文章寫,“過不了多久,你的手機上,就能用上央行的數字貨幣,支付可以“離線”進行,不用網絡和手機信號,手機和手機之間碰一碰,就可以完成.

1900/1/1 0:00:00
2020 焦點前瞻:讀懂跨鏈技術的核心,了解區塊鏈互操作性_OSMO

撰文:LucasNuzzi 編譯:詹涓 來源:鏈聞 本文為鏈聞推出的「2020焦點前瞻」系列文章的一篇。2019年是Cosmos生態起步的年份.

1900/1/1 0:00:00
ads