WebAssembly - Введение

WebAssembly также называется WASM, который был впервые представлен в 2017 году. Крупные технологические компании, стоящие за созданием WebAssembly, - это Google, Apple, Microsoft, Mozilla и W3C.

Ходят слухи, что WebAssembly собирается заменить Javascript из-за его более быстрого выполнения, но это не так. WebAssembly и Javascript предназначены для совместной работы над решением сложных проблем.

Потребность в WebAssembly

Пока у нас есть только Javascript, который может успешно работать внутри браузера. Есть очень тяжелые задачи, которые сложно выполнять в браузерах с использованием javascript.

Назовем лишь некоторые из них: распознавание изображений, приложения для автоматизированного проектирования (САПР), увеличение живого видео, виртуальная реальность и дополненная реальность, музыкальные приложения, научная визуализация и моделирование, игры, редактирование изображений / видео и т. Д.

WebAssembly - это новый язык с двоичными инструкциями, которые могут загружаться и выполняться быстрее. Задача, изложенная выше, может быть легко выполнена на языках высокого уровня, таких как C, C ++, Rust и т. Д. Нам нужен способ, чтобы код, который у нас есть на C, C ++, Rust, можно было скомпилировать и использовать в веб-браузерах. То же самое достигается с помощью WebAssembly.

Когда код WebAssembly загружается внутри браузера. Затем браузер выполняет преобразование в машинный формат, понятный процессорам.

Для javascript код необходимо загрузить, проанализировать и преобразовать в машинный формат. На это уходит много времени, и для тяжелых задач, как мы упоминали ранее, может быть очень медленно.

Работа WebAssembly

Языки высокого уровня, такие как C, C ++ и Rust, компилируются в двоичный формат, то есть .wasm и текстовый формат .wat.

Исходный код, написанный на C, C ++ и Rust, скомпилирован в .wasmс помощью компилятора. Вы можете использовать Emscripten SDK для компиляции C / C ++ в.wasm.

Поток следующий -

Код C / C ++ можно скомпилировать в .wasmс использованием Emscripten SDK. Позже.wasm код можно использовать с помощью javascript в вашем html файле для отображения вывода.

Ключевые концепции WebAssembly

Ключевые концепции описаны ниже -

Модуль

Модуль - это объект, который компилируется браузером в исполняемый машинный код. Говорят, что модуль не имеет состояния и может совместно использоваться Windows и веб-воркерами.

объем памяти

Память в WebAssembly - это arraybufferкоторый содержит данные. Вы можете выделить память, используя Javascript api WebAssembly.memory ().

Стол

Таблица в WebAssembly - это типизированный массив, который находится вне памяти WebAssembly и в основном имеет ссылку на функции. Он хранит адрес памяти функций.

Пример

Экземпляр - это объект, который будет иметь все экспортируемые функции, которые можно вызывать из javascript для выполнения в браузере.