WebAssembly - Модули
Мы видели, как получить файл .wasm из кода c / c ++. В этой главе мы преобразуем wasm в модуль WebAssembly и выполним его в браузере.
Давайте использовать код Факториала C ++, как показано ниже -
int fact(int n) {
if ((n==0)||(n==1))
return 1;
else
return n*fact(n-1);
}
Откройте Wasm Explorer, доступный по адресу https://mbebenita.github.io/WasmExplorer/ as shown below −
В первом столбце есть функция факториала C ++, во втором столбце - текстовый формат WebAssembly, а в последнем столбце - код сборки x86.
Формат текста WebAssembly -
(module
(table 0 anyfunc)
(memory $0 1)
(export "memory" (memory $0))
(export "_Z4facti" (func $_Z4facti))
(func $_Z4facti (; 0 ;) (param $0 i32) (result i32)
(local $1 i32)
(set_local $1
(i32.const 1)
)
(block $label$0
(br_if $label$0
(i32.eq
(i32.or
(get_local $0)
(i32.const 1)
)
(i32.const 1)
)
)
(set_local $1
(i32.const 1)
)
(loop $label$1
(set_local $1
(i32.mul
(get_local $0)
(get_local $1)
)
)
(br_if $label$1
(i32.ne
(i32.or
(tee_local $0
(i32.add
(get_local $0)
(i32.const -1)
)
)
(i32.const 1)
)
(i32.const 1)
)
)
)
)
(get_local $1)
)
)
Функция C ++ fact был экспортирован как «_Z4facti»В текстовом формате WebAssembly.
Нажмите кнопку загрузки, чтобы загрузить код wasm и сохранить файл как factorial.wasm.
Теперь, чтобы преобразовать код .wasm в модуль, мы должны сделать следующее:
Шаг 1
Преобразуйте .wasm в буфер массива с помощью ArrayBuffer. Объект ArrayBuffer вернет вам буфер двоичных данных фиксированной длины.
Шаг 2
Байты из ArrayBuffer должны быть скомпилированы в модуль с помощью WebAssembly.compile(buffer) функция.
В WebAssembly.compile() функция компилирует и возвращает WebAssembly.Module из заданных байтов.
Вот код Javascript, который обсуждается на шагах 1 и 2.
<script type="text/javascript">
let factorial;
fetch("factorial.wasm")
.then(bytes => bytes.arrayBuffer())
.then(mod => WebAssembly.compile(mod))
.then(module => {return new WebAssembly.Instance(module) })
.then(instance => {
factorial = instance.exports._Z4facti;
console.log('Test the output in Brower Console by using factorial(n)');
});
</script>
Код Пояснение
Выборка API браузера Javascript используется для получения содержимого factorial.wasm.
Содержимое преобразуется в байты с помощью arrayBuffer ().
Модуль создается из байтов путем вызова WebAssembly.compile (mod).
Экземпляр модуля создается с использованием нового
WebAssembly.Instance(module)
Факториальная функция export _Z4facti назначается переменной factorial с помощью WebAssembly.Module.exports ().
пример
Вот module.html вместе с кодом javascript -
module.html
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>WebAssembly Module</title>
</head>
<body>
<script>
let factorial;
fetch("factorial.wasm")
.then(bytes => bytes.arrayBuffer())
.then(mod => WebAssembly.compile(mod))
.then(module => {return new WebAssembly.Instance(module) })
.then(instance => {
factorial = instance.exports._Z4facti;
console.log('Test the output in Browser Console by using factorial(n)');
});
</script>
</body>
</html>
Вывод
Запустите module.html в браузере, чтобы увидеть результат -