эксперимента решил скомпилировать простенькую функцию генератор псевдослучайных чисел:
#include <stdint.h>
uint8_t rand(void) {
static uint8_t rand = 0;
rand = rand * 109 + 89;
return rand;
}
Команда компиляции выглядит так (не пугайтесь символа ^ - он используется в Windows, чтобы разбивать команду на несколько строк):
emcc wasm-module.c -Os -flto ^
-o wasm-module.js ^
-s MODULARIZE ^
-s EXPORTED_FUNCTIONS="['_rand']" ^
-s EXPORTED_RUNTIME_METHODS="['ccall', 'cwrap']"
В итоге на выходе я получил достаточно маленький файл .wasm (156 байт). Таким маленьким он получился после того, как я добавил опцию компилятора -Os. С -O2 к примеру размер файла чо-то огромный выходит.
Кроме того создаётся .js файл, который нужно инклудить внутри своего скрипта под node.js. И всё работает:
"use strict";
const wasmModuleFactory = require("./wasm-module");
(async () => {
const instance = await wasmModuleFactory();
console.log(instance._rand());
console.log(instance._rand());
console.log(instance._rand());
})().catch(error => console.log(error));
Выводит в консоль:
89
62
191
Вот только что меня с ходу смутило. Почему сгенерированный JS файл, который я инклужу в node.js такого огромного размера? 15 килобайт в минифицированном виде. Что такого он там делает? Я думал, имея скомпилированный WASM бинарник, можно относительно без проблем парой строк кода запустить этот код хоть в node.js, хоть в Google Chrome. А тут оказывается, что ещё какой-то огромный автосгенерированный JS фреймворк нужно инклудить. Как можете увидеть, никаких зависимостей моя программа на Си не требует. Так в чём же дело?
https://t.me/WebAssembly_ru попробуй тут поинтересуйся
скомпиль в режиме без минификаций и увидишь сколько там всего тащится
Я пробовал васм в браузере, там три строчки жс кода нужно для подключения. Видимо твоя проблема связана с емкриптеном.зачем он вообще тебе?
Обсуждают сегодня