- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何从 WebAssembly 函数返回 JavaScript 字符串?
以下模块可以用 C(++) 编写吗?
export function foo() {
return 'Hello World!';
}
另外:我可以将其传递给 JS 引擎进行垃圾收集吗?
最佳答案
WebAssembly 本身并不支持字符串类型,而是支持 i32
/i64
/f32
/f64
value types以及用于存储的 i8
/i16
。
您可以使用以下方式与 WebAssembly 实例交互:
exports
,从 JavaScript 调用 WebAssembly,WebAssembly 返回单个值类型。imports
其中 WebAssembly 调用 JavaScript,具有任意数量的值类型(注意:必须在模块编译时知道计数,这不是数组,也不是可变参数)。Memory.buffer
,这是一个 ArrayBuffer
,可以使用(以及其他)Uint8Array
进行索引。这取决于您想要做什么,但似乎直接访问缓冲区是最简单的:
const bin = ...; // WebAssembly binary, I assume below that it imports a memory from module "imports", field "memory".
const module = new WebAssembly.Module(bin);
const memory = new WebAssembly.Memory({ initial: 2 }); // Size is in pages.
const instance = new WebAssembly.Instance(module, { imports: { memory: memory } });
const arrayBuffer = memory.buffer;
const buffer = new Uint8Array(arrayBuffer);
如果您的模块有 start
function然后它在实例化时被执行。否则你可能会有一个你称之为的导出,例如instance.exports.doIt()
。
完成后,您需要获取内存中的字符串大小+索引,您也可以通过导出公开它:
const size = instance.exports.myStringSize();
const index = instance.exports.myStringIndex();
然后您可以从缓冲区中读取它:
let s = "";
for (let i = index; i < index + size; ++i)
s += String.fromCharCode(buffer[i]);
请注意,我正在从缓冲区读取 8 位值,因此我假设字符串是 ASCII。这就是 std::string
将为您提供的内容(内存中的索引将是 .c_str()
返回的内容),但是要公开其他内容(例如 UTF-8),您需要需要使用支持UTF-8的C++库,然后自己从JavaScript读取UTF-8,获取码点,并使用String.fromCodePoint
。
您还可以依赖以 null 结尾的字符串,但我在这里没有这样做。
您还可以使用TextDecoder
API一旦通过创建 ArrayBufferView
在浏览器中更广泛地使用它进入 WebAssembly.Memory
的 buffer
(这是一个 ArrayBuffer
)。
相反,如果您正在执行从 WebAssembly 登录到 JavaScript 之类的操作,那么您可以如上所述公开内存,然后从 WebAssembly 声明一个使用大小 + 位置调用 JavaScript 的导入。您可以将您的模块实例化为:
const memory = new WebAssembly.Memory({ initial: 2 });
const arrayBuffer = memory.buffer;
const buffer = new Uint8Array(arrayBuffer);
const instance = new WebAssembly.Instance(module, {
imports: {
memory: memory,
logString: (size, index) => {
let s = "";
for (let i = index; i < index + size; ++i)
s += String.fromCharCode(buffer[i]);
console.log(s);
}
}
});
这里有一个警告,如果您增加内存(通过 JavaScript 使用 Memory.prototype.grow
或使用 grow_memory
操作码),则 ArrayBuffer
被阉割,您需要重新创建它。
关于垃圾回收:WebAssembly.Module
/WebAssembly.Instance
/WebAssembly.Memory
都是JavaScript引擎收集的垃圾,但那是一把相当大的锤子。您可能需要 GC 字符串,但目前对于位于 WebAssembly.Memory 内的对象来说这是不可能的。我们已经讨论过adding GC support in the future .
关于javascript - 如何从 WebAssembly 函数返回 JavaScript 字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41353389/
我在 WebAssembly 中看到的每个数据部分示例都使用字符串,即 (data (i32.const 16) "Hello World") 如何将这些部分与二进制数据一起使用?我怎么能做一些等同于
详细介绍 WebAssembly 的主要站点,https://webassembly.org/ ,自 1.0 版发布以来似乎没有更新,甚至是功能路线图。 docs on MDN好像也好不到哪里去,th
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
例如,C 没有与 Rust 相同的安全解决方案,但是用 Rust 编写的 WebAssembly 是否具有 Rust 的优点? 用 Rust 编写并转换为 WebAssembly 的程序会比用 C 编
垃圾收集语言,例如 Go 和 AssemblyScript,需要随应用程序一起提供运行时来处理垃圾收集。这导致比没有垃圾收集的语言更大的二进制大小。编译为 WebAssembly 的各种语言的二进制大
Webassembly 仅提供一种更高级的浮点运算:平方根。 它没有任何其他通常在 CPU 中实现的功能,例如幂和三角函数,官方常见问题解答中解释了这一基本原理: WebAssembly doesn’
有人可以分享语法来静态创建具有某些元素的表并引用它吗?我找不到这样做的任何 Web 程序集代码。 还有一些细节,比如我可以有多个列,如果索引不在表中会发生什么等会有所帮助吗? 最佳答案 (针对 202
有人可以分享语法来静态创建具有某些元素的表并引用它吗?我找不到这样做的任何 Web 程序集代码。 还有一些细节,比如我可以有多个列,如果索引不在表中会发生什么等会有所帮助吗? 最佳答案 (针对 202
即一方面,预编译代码更难阅读,因此更难以有意义地更改浏览器代码。 它如何比 JS 更“沙盒化”,这是否使它不那么容易被破解? “WebAssembly 被指定在安全的沙盒执行环境中运行。” - htt
https://webassembly.github.io/demo/说:“实现了完整的执行语义。”听起来 MVP 已经完成,但到底缺少什么,或者我做错了什么? 浪费: (module (me
我正在试验 WASM,我想将图片编码为 WebP 以学习 WASM。 我正在尝试编译 libwebp到单个 mjs 文件中。具体来说,encoding utility .我正在使用 Emscripte
我的问题类似于this one ,但不是属于 Blazor server 应用程序,我在 Blazor webassembly 应用程序的上下文中询问。我意识到在这个浏览器执行上下文中只有一个 (UI
我想使用这个很棒的包:https://github.com/hpcc-systems/hpcc-js-wasm它将 Webassembly (graphizlib.wasm) 与要使用的 Javasc
没有使用 indirect_call 的例子可在线使用。基于语义文档,我试过 (call_indirect (i32.const 0) (i32.const 0) ) 数字是随
我需要将 wasm 应用程序直接嵌入到 html 页面本身,而不是从单独的文件中加载它(例如通过 xhr)。到目前为止,我设法通过将字节直接“打印”到 Uint8Array 中来嵌入它(见下文),但它
我需要一个 WebAssembly 的“br_table”指令示例,因为我不知道如何直接以 WebAssembly 文本格式使用该指令。 就像下面的代码,我看不出它的构造结构对应的是哪一部分。哪一部分
是否有任何工具(目前)可以将 wasm 模块编译为 native 可执行文件(例如 ELF 或 .exe 文件)?类似 emscripten 的东西,但反过来。如果做不到这一点,有没有其他方法可以在浏
我尝试了 Blazor Webassembly。我在 Visual Studio 中创建了一个新的 Blazor Webassembly 项目。这为我们提供了一个基本的示例项目,其中包含可以通过单击增
我刚刚开始研究 WebAssembly MVP,并注意到无法访问堆栈和堆栈指针,或者实际上没有任何结构化异常处理支持(抛出/捕获)等。 鉴于它应该是一个 C 编译目标,它肯定可以实现 setjmp 和
在 Uno Platform for WebAssembly 中实现 URL 深度链接的任何线索或方向? 我看到它在以下项目中实现,可以在 https://platform.uno/showcases
我是一名优秀的程序员,十分优秀!