您好,登錄后才能下訂單哦!
本篇內容介紹了“為什么使用Rust編寫系統代碼”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
作為一個相當完善的移動操作系統,Android 系統涉及到很多組件。如果寬泛的來講可以分成兩大部分,應用生態和操作系統本身。而對于開發者來說,所選擇的編程語言會根據正在開發的 Android 部分有所不同。
對于應用開發者來說,Java 和 Kotlin 是比較流行的選擇;而對于從事操作系統以及內部底層的開發者來說,C 和 C++ 是比較熱門的選擇。而今天谷歌為操作系統開發者增加了第 3 個選擇-- Rust,因為 Android Open Source Project 現在支持 Rust 編程語言來開發操作系統了。
Android 系統的底層需要 C 和 C++ 等系統編程語言。這些語言為開發者提供了控制和可預測性,這在訪問低級系統資源和硬件時非常重要。不幸的是,C 和 C++ 并不能提供內存安全保證,使得它們容易出現錯誤和安全漏洞。開發者有責任在這些語言上管理內存壽命,但在復雜和多線程的代碼庫中,這說起來容易做起來難。
C 和 C++ 共同構成了 Android 平臺上數以千萬計的代碼行。這些內存安全漏洞成為最難解決的代碼錯誤來源,占 Android 高嚴重度安全漏洞的 70% 左右。單純的修復這些 bug 變得不足以處理問題,更好的方法是在一開始就預防這些 bug。
由于缺乏內存安全保障,迫使開發者在嚴格約束的無權限沙盒內運行Android進程。但沙盒在資源上的成本很高,會消耗額外的開銷,并引入延遲。沙盒也不能完全消除代碼的漏洞,而且由于 bug 密度高,沙盒的功效會降低,進一步讓攻擊者連鎖多個漏洞。
另一個限制,雖然不是 C 和 C++ 獨有的,但適用于所有的內存安全問題,那就是錯誤狀態必須在工具化的代碼中實際觸發,才能被檢測到。所以即使你的代碼有很好的測試,實際的 bug 也可能一直沒有被發現。而當發現bug時,讓它們得到修復又是另一項任務,涉及到一個漫長而昂貴的過程,不一定能得到正確的修復。因此,bug 檢測變得不可靠,鑒于這些局限性,bug 預防是更好的方法。
Rust 通過使用編譯時檢查和運行時檢查相結合的方式提供內存安全保證,以強制執行對象的壽命/所有權,并確保內存訪問是有效的。在實現這種安全性的同時,還能提供與C和C++相當的性能。Rust 還減少了對沙盒的需求,讓開發人員有更多的開銷空間來引入更安全、更輕量的新功能。
雖然 Rust 確實有它的好處,但一夜之間將整個Android操作系統換成Rust是不可行的。而且可能根本不需要這樣做,因為大多數 Android 的內存錯誤都發生在新的或最近修改的代碼中,大約有50%的代碼是不到一年的。谷歌認為,其內存安全語言的工作最好集中在新的開發上,而不是重寫成熟的C和C++代碼。
Rust還專注于防止bug,而不是嚴重依賴檢測bug,從而提高代碼的正確性。它有幾個關鍵特性,比如內存安全、數據并發、更有表現力的類型系統、默認的不可變引用和變量、更安全的整數處理、標準庫中更好的錯誤處理等等。
Google表示,在過去的18個月里,它一直在為Android開源項目添加Rust支持。但在Android平臺上添加一門新語言是一項巨大的工程。一些工具鏈和依賴關系需要維護,測試基礎設施和工具必須更新,開發人員需要接受培訓。
“為什么使用Rust編寫系統代碼”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。