WebAssembly,wasm返回字符串

2021-04-22 08:50:32

参考地址 emscripten、 WebAssembly,传递字符串给c函数


可以用这个方法来实现 wasm AES加密


也可以参考现成的库,来改成自己需要的方法。 aes-wasm

下面看具体的实例。


下面的代码是一个C函数,实现简单的字符串拼接,然后返回拼接的字符串。

#include <stdio.h>#include <string>

 char* EMSCRIPTEN_KEEPALIVE outName(char *n){

 char xhName[] = "xuanhun";
 strcat(n, xhName);
 return n;}


下面使用命令进行编译:

emcc hello.cc -o test2.js


然后在页面中引用:

<script>
        Module = {};
        Module.onRuntimeInitialized = function () {

 var ptr = allocate(
            intArrayFromString("玄魂"),
 'i8',
              ALLOC_NORMAL);

 var retPtr = Module._outName(ptr);

 var resValue = Pointer_stringify(retPtr);
 console.log(resValue);

            _free(ptr);

        }
 </script>
 <script src="test2.js"></script>


上面的代码我们核心部分逐行分析一下:

  var ptr = allocate(intArrayFromString("玄魂"), 
 'i8', ALLOC_NORMAL);


上面的intArrayFromString方法,将字符串转换为UTF8的char数组,然后allocate 方法开辟内存空间存储数据,返回指针。

 var retPtr = Module._outName(ptr);


调用C导出函数,传入字符串指针。

 var resValue = Pointer_stringify(retPtr);


调用Pointer_stringify胶水函数,将c返回的指针转换为字符串。

   _free(ptr);


释放内存。

下面查看下运行结果:




  • 2020-05-07 13:21:25

    JS中获取 DOM 元素的绝对位置实例详解

    在操作页面滚动和动画时经常会获取 DOM 元素的绝对位置,例如 本文 左侧的悬浮导航,当页面滚动到它以前会正常地渲染到文档流中,当页面滚动超过了它的位置,就会始终悬浮在左侧。

  • 2020-05-07 13:42:13

    场景切换的集合移动,旋转,淡入淡出等

    两个场景(即两个div视图)切换的时候,如果想添加个过渡动画,除了可以使用js来实现,还可以通过CSS3的animation属性来实现。 (注意:Internet Explorer 9 以及更早的版本不支持 animation 属性。)

  • 2020-05-07 13:43:02

    css模拟开关按钮

    之前我们为大家分享过很多款各式各样的CSS3开关切换按钮,很多还是非常富有创意的,比如这里的多组超具创意的CSS3开关切换按钮和纯CSS3灯光开关动画。今天我们要带来另外一款外观很漂亮的纯CSS3开关切换按钮动画,它模拟了电灯的开关,并且在开和关之间切换时按钮的背景会有不同的变化,看起来非常不错。

  • 2020-05-07 18:40:35

    CSS让页面平滑滚动

    凡是需要滚动的地方都加一句scroll-behavior:smooth就好了!