Rust Web 全棧開發之編寫 WebAssembly 應用

来源:https://www.cnblogs.com/QiaoPengjun/archive/2023/06/04/17455654.html
-Advertisement-
Play Games

# Rust Web 全棧開發之編寫 WebAssembly 應用 MDN Web Docs: 官網: ## 項目結構 和 功能 **Web App 教師註冊 WebService WebAssembly App 課程管理** ## 什麼是 WebAssembly - WebAssembly 是一種 ...


Rust Web 全棧開發之編寫 WebAssembly 應用

MDN Web Docs:https://developer.mozilla.org/zh-CN/docs/WebAssembly

官網:https://webassembly.org/

項目結構 和 功能

Web App 教師註冊 <-> WebService <-> WebAssembly App 課程管理

什麼是 WebAssembly

  • WebAssembly 是一種新的編碼方式,可以在現代瀏覽器中運行
    • 它是一種低級的類彙編語言
    • 具有緊湊的二進位格式
    • 可以接近原生的性能運行
    • 併為 C/C ++ 、 C# 、 Rust 等語言提供一個編譯目標,以便它們可以在 Web上運行
    • 它也被設計為可以與 JavaScript 共存,允許兩者一起工作。

機器碼

  • 機器碼是電腦可直接執行的語言
  • 彙編語言比較接近機器碼

ASSEMBLY -> ASSEMBLER -> MACHINE CODE

機器碼與 CPU 架構

  • 不同的 CPU 架構需要不同的機器碼和彙編
  • 高級語言可以“翻譯”成機器碼,以便在 CPU 上運行
  • SOURCE CODE
    • x64
    • x86
    • ARM

WebAssembly

  • WebAssembly 其實不是彙編語言,它不針對特定的機器,而是針對瀏覽器的。
  • WebAssembly 是中間編譯器目標
  • SOURCE CODE
    • WASM
      • x64
      • x86
      • ARM

WebAssembly 是什麼樣的?

  • 文本格式 .wat
  • 二進位格式: .wasm

WebAssembly 能做什麼

  • 可以把你編寫 C/C++ 、 C# 、 Rust 等語言的代碼編譯成 WebAssembly 模塊
  • 你可以在 Web 應用中載入該模塊,並通過 JavaScript 調用它
  • 它並不是為了替代 JS ,而是與 JS 一起工作
  • 仍然需要 HTML 和 JS ,因為WebAssembly 無法訪問平臺 API ,例如 DOM , WebGL...

WebAssembly 如何工作

  • 這是 C/C++ 的例子

Hello.c -> EMSCRIPTEN(編譯器) -> hello.wasm hello.js hello.html

WebAssembly 的優點

  • 快速、高效、可移植
    • 通過利用常見的硬體能力, WebAssembly 代碼在不同平臺上能夠以接近本地速度運行。
  • 可讀、可調試
    • WebAssembly 是一門低階語言,但是它有確實有一種人類可讀的文本格式(其標準最終版本目前仍在編製),這允許通過手工來寫代碼,看代碼以及調試代碼。
  • 保持安全
    • WebAssembly 被限制運行在一個安全的沙箱執行環境中。像其他網路代碼一樣,它遵循瀏覽器的同源策略和授權策略。
  • 不破壞網路
    • WebAssembly 的設計原則是與其他網路技術和諧共處並保持向後相容。

Rust WebAssembly 部分相關 crate

  • wasm-bindgen
  • wasm-bindgen-future
  • web-sys
  • js-sys

搭建環境

Rust 官網:https://www.rust-lang.org/zh-CN/what/wasm

Rust and WebAssembly:https://rustwasm.github.io/docs/book/

Rust和WebAssembly中文文檔:https://rustwasm.wasmdev.cn/docs/book/

安裝

wasm-pack

下載安裝地址:https://rustwasm.github.io/wasm-pack/installer/

Install wasm-pack

You appear to be running a *nix system (Unix, Linux, MacOS). Install by running:

curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh

If you're not on *nix, or you don't like installing from curl, follow the alternate instructions below.

cargo-generate

cargo-generate helps you get up and running quickly with a new Rust project by leveraging a pre-existing git repository as a template.

Install cargo-generate with this command:

cargo install cargo-generate
~ via 

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ## 引言 > 類(class)的使用分為兩種——基於對象(object Based)和麵向對象(object oriented) > > 基於對象是指,程式設計中單一的類,和其他類沒有任何關係 > > 單一的類又分為:不帶指針的類(class without pointer members)和帶指 ...
  • # SpringCloud Gateway-服務網關 ## 1.Gateway介紹 ### 1.1引出問題 **沒有使用網關服務時:** **使用網關服務後:** ### 1.2Gateway網路拓撲圖 ![Gateway網路拓撲圖](https://liyuelian.oss-cn-shenzhe ...
  • # 1.初識元組 列表非常適合用於存儲在程式運行期間可能變化的數據集。列表是可以修改的。 然而,有時候需要創建一系列不可修改的元素,元組可以滿足這種需求 python將不能修改的值稱為不可變的,而不可變的列表被稱為元組。 元組看起來猶如列表,但使用圓括弧而不是方括弧來標識。 其語法格式:元組變數名 ...
  • 在`pandas`中,索引(`index`)是用於訪問數據的關鍵。 它為數據提供了基於標簽的訪問能力,類似於字典,可以根據標簽查找和訪問數據。 而`pandas`的軸(`axis`)是指數據表中的一個維度,可以理解為表格中的行和列。 通過指定軸,我們可以對數據進行切片、篩選、聚合等操作。 下麵簡要介 ...
  • # FileReader 和 FileWriter ### 一、 FileReader 和 File Writer 介紹 FileReader 和 FileWriter 是字元流,即按照字元來操作 io ### 二、 FileReader 相關方法 ![](https://img2023.cnblo ...
  • ## 1. 環境配置 - Springboot 2.7.8 - h2 2.1.214 ## 2. POM文件 - 引入springboot parent pom 點擊查看代碼 ``` org.springframework.boot spring-boot-starter-parent 2.7.8 ...
  • 某日小二參加XXX科技公司的C++工程師開發崗位5面: > 面試官:struct和class有什麼區別? > > 小二:在C++中,struct和class的唯一區別是預設的訪問控制。struct預設的成員是public的,而class的預設成員是private的。 > > 面試官:struct、c ...
  • # 前言 最近在開發文件存儲服務,需要符合s3的協議標準,可以直接接入aws-sdk,本文針對sdk發出請求的鑒權信息進行重新組合再簽名驗證有效性,sdk版本如下 ```xml software.amazon.awssdk s3 2.20.45 ``` # 演算法解析 首先對V4版本簽名演算法的數據結構 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...