WebAssembly-C 작업

이 장에서는 간단한 C 프로그램을 자바 스크립트로 컴파일하고 브라우저에서 동일한 작업을 실행할 것입니다.

예를 들어- C Program

#include<stdio.h> 
int square(int n) { 
   return n*n; 
}

wa / 폴더에 emsdk를 설치했습니다. 같은 폴더에 다른 폴더 cprog /를 만들고 위 코드를 square.c로 저장합니다.

이전 장에서 이미 emsdk를 설치했습니다. 여기서는 위의 c 코드를 컴파일하기 위해 emsdk를 사용할 것입니다.

아래와 같이 명령 프롬프트에서 test.c를 컴파일하십시오.

emcc square.c -s STANDALONE_WASM –o findsquare.wasm

emcc 명령은 코드 컴파일을 처리하고 .wasm 코드를 제공합니다. .wasm 파일 만 제공하는 STANDALONE_WASM 옵션을 사용했습니다.

예- findsquare.html

<!doctype html> 
<html>
   <head>
      <meta charset="utf-8">
      <title>WebAssembly Square function</title>
      <style>
         div { 
            font-size : 30px; text-align : center; color:orange; 
         } 
      </style>
   </head> 
   <body>
      <div id="textcontent"></div>
      <script> 
      let square; fetch("findsquare.wasm").then(bytes => bytes.arrayBuffer()) 
      .then(mod => WebAssembly.compile(mod)) .then(module => {
         return new WebAssembly.Instance(module) 
      }) 
      .then(instance => {
         square = instance.exports.square(13); 
         console.log("The square of 13 = " +square);         
         document.getElementById("textcontent").innerHTML = "The square of 13 = " +square; 
      }); 
      </script>
   </body>
</html>

산출

출력은 다음과 같습니다.