WebAssembly-모듈

c / c ++ 코드에서 .wasm 파일을 얻는 방법을 살펴 보았습니다. 이 장에서는 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 Text 형식으로합니다.

다운로드 버튼을 클릭하여 wasm 코드를 다운로드하고 파일을 factorial.wasm으로 저장하십시오.

이제 .wasm 코드를 모듈로 변환하려면 다음을 수행해야합니다.

1 단계

다음을 사용하여 .wasm을 배열 버퍼로 변환하십시오. ArrayBuffer. ArrayBuffer 객체는 고정 길이 이진 데이터 버퍼를 반환합니다.

2 단계

ArrayBuffer의 바이트는 다음을 사용하여 모듈로 컴파일해야합니다. WebAssembly.compile(buffer) 함수.

그만큼 WebAssembly.compile() 함수는 주어진 바이트에서 WebAssembly.Module을 컴파일하고 반환합니다.

다음은 1 단계와 2 단계에서 설명하는 Javascript 코드입니다.

<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>

코드 설명

  • Javascript 브라우저 API 가져 오기는 factorial.wasm의 내용을 가져 오는 데 사용됩니다.

  • 내용은 arrayBuffer ()를 사용하여 바이트로 변환됩니다.

  • 모듈은 WebAssembly.compile (mod)를 호출하여 바이트에서 생성됩니다.

  • 모듈의 인스턴스는 new를 사용하여 생성됩니다.

    WebAssembly.Instance(module)

  • 팩토리얼 함수 export _Z4facti는 WebAssembly.Module.exports ()를 사용하여 변수 팩토리얼에 할당됩니다.

여기, javascript 코드와 함께 module.html이 있습니다-

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을 실행하여 출력을 확인하십시오.