WebAssembly - जावास्क्रिप्ट एपीआई

इस अध्याय में, हम समझेंगे कि कैसे wasm कोड को लोड किया जाए और उन्हें जावास्क्रिप्ट वेबसीम एपीआई की मदद से ब्राउज़र में निष्पादित किया जाए।

यहां कुछ महत्वपूर्ण एपीआई हैं, हम wasm कोड को निष्पादित करने के लिए पूरे ट्यूटोरियल में उपयोग करने जा रहे हैं।

  • लाने () ब्राउज़र एपीआई
  • WebAssembly.compile
  • WebAssembly.instance
  • WebAssembly.instantiate
  • WebAssembly.instantiateStreaming

इससे पहले कि हम WebAssembly javascript API की चर्चा करें, API और आउटपुट का परीक्षण करने के लिए हम निम्नलिखित C प्रोग्राम और .m एक्सप्लोरर की मदद से c प्रोग्राम से उत्पन्न .wasm कोड का उपयोग करने जा रहे हैं।

सी कार्यक्रम के लिए एक उदाहरण इस प्रकार है -

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

हम WASM एक्सप्लोरर का उपयोग करेंगे, जो कि wasm कोड प्राप्त करने के लिए -

WASM कोड डाउनलोड करें और एपीआई के परीक्षण के लिए इसका उपयोग करें।

लाने () ब्राउज़र एपीआई

fetch () API का अर्थ है .wasm नेटवर्क संसाधन को लोड करना।

<script>
   var result = fetch("findsquare.wasm");
   console.log(result);
</script>

यह एक वादा लौटाता है जैसा कि नीचे दिखाया गया है -

आप wasm नेटवर्क संसाधन लाने के लिए XMLHttpRequest विधि का उपयोग भी कर सकते हैं।

WebAssembly.compile ()

एपीआई जिम्मेदारी उन मॉड्यूल विवरणों को संकलित करने के लिए है जो कि .wasm से प्राप्त होते हैं।

वाक्य - विन्यास

सिंटैक्स नीचे दिया गया है -

WebAssembly.compile(buffer);

मापदंडों

Buffer - संकलित करने के लिए इनपुट के रूप में देने से पहले .wasm से इस कोड को। टाइप में परिवर्तित किया जा सकता है।

प्रतिलाभ की मात्रा

यह एक वादा लौटाएगा जिसमें संकलित मॉड्यूल होगा।

उदाहरण

आइए हम एक उदाहरण देखें, जो webAssembly.compile () का उपयोग करके संकलित मॉड्यूल के रूप में आउटपुट देता है।

<script> 
   fetch("findsquare.wasm") .then(bytes => bytes.arrayBuffer()) 
   .then(mod => {
      var compiledmod = WebAssembly.compile(mod);
      compiledmod.then(test=> {
         console.log(test); 
      })
   })
</script>

उत्पादन

कंसोल.लॉग, जब ब्राउज़र में जाँच की जाती है, आपको संकलित मॉड्यूल विवरण देगा -

मॉड्यूल में आयातकों, निर्यातों और कस्टम्स के साथ एक कंस्ट्रक्टर ऑब्जेक्ट है। संकलित मॉड्यूल के अधिक विवरण प्राप्त करने के लिए, अगला एपीआई देखें।

WebAssembly.instance

WebAssembly.instance का उपयोग करते हुए, एपीआई आपको संकलित मॉड्यूल के निष्पादन योग्य उदाहरण देगा जो आउटपुट प्राप्त करने के लिए आगे निष्पादित किया जा सकता है।

वाक्य - विन्यास

सिंटैक्स नीचे दिया गया है -

new WebAssembly.Instance(compiled module)

प्रतिलाभ की मात्रा

रिटर्न वैल्यू एक्सपोर्ट फ़ंक्शन के एरे के साथ एक ऑब्जेक्ट होगा जिसे निष्पादित किया जा सकता है।

उदाहरण

<script> 
   fetch("findsquare.wasm") 
      .then(bytes => bytes.arrayBuffer())
      .then(mod => WebAssembly.compile(mod)).then(module => {
         let instance = new WebAssembly.Instance(module); 
         console.log(instance); 
      })
</script>

उत्पादन

आउटपुट हमें नीचे दिखाए गए अनुसार निर्यात फ़ंक्शन का एक सरणी देगा -

आप स्क्वायर फंक्शन देख सकते हैं, कि हम C कोड से संकलित किया गया है।

वर्ग फ़ंक्शन को निष्पादित करने के लिए, आप निम्न कार्य कर सकते हैं -

<script>
   fetch("findsquare.wasm") 
   .then(bytes => bytes.arrayBuffer()) 
   .then(mod => WebAssembly.compile(mod)) 
   .then(module => { 
      let instance = new WebAssembly.Instance(module);
      console.log(instance.exports.square(15));
   })
</script>

उत्पादन होगा -

225

WebAssembly.instantiate

यह एपीआई मॉड्यूल को एक साथ संकलित और त्वरित करने का ध्यान रखता है।

वाक्य - विन्यास

वाक्य विन्यास इस प्रकार है -

WebAssembly.instantiate(arraybuffer, importObject)

मापदंडों

arraybuffer - .wasm से कोड को इंस्टेंट के इनपुट के रूप में देने से पहले टाइप किए गए ऐरे या arraybuffer में बदलना होता है।

importObject- इंपोर्ट ऑब्जेक्ट में मेमोरी का विवरण होना चाहिए, इंपोर्टेड फंक्शन्स का उपयोग मॉड्यूल के अंदर किया जाना है। यह एक खाली मॉड्यूल ऑब्जेक्ट हो सकता है, मामले में, साझा करने के लिए कुछ भी नहीं है।

प्रतिलाभ की मात्रा

यह एक वादा लौटाएगा, जिसमें मॉड्यूल और उदाहरण विवरण होंगे।

उदाहरण

<script type="text/javascript">
   const importObj = {
      module: {}
   };
   fetch("findsquare.wasm")
      .then(bytes => bytes.arrayBuffer())
      .then(module => WebAssembly.instantiate(module, importObj)) 
      .then(finalcode => { 
         console.log(finalcode); console.log(finalcode.instance.exports.square(25)); 
      }); 
</script>

उत्पादन

जब आप कोड निष्पादित करते हैं, तो आपको नीचे उल्लिखित आउटपुट मिलेगा।

WebAssembly.instantiateStreaming

यह API दिए गए .wasm कोड से WebAssembly मॉड्यूल को इंस्टेंट करने के साथ-साथ संकलन का ख्याल रखता है।

वाक्य - विन्यास

सिंटैक्स नीचे दिया गया है -

WebAssembly.instantiateStreaming(wasmcode, importObject);

मापदंडों

wasmcode - भ्रूण या किसी अन्य एपीआई से प्रतिक्रिया जो ततैया कोड देती है और एक वादा वापस करती है।

importObject- इंपोर्ट ऑब्जेक्ट में मेमोरी का विवरण होना चाहिए, इंपोर्टेड फंक्शन्स का उपयोग मॉड्यूल के अंदर किया जाना है। यह साझा करने के लिए कुछ भी नहीं होने की स्थिति में एक खाली मॉड्यूल ऑब्जेक्ट हो सकता है।

प्रतिलाभ की मात्रा

यह एक वादा लौटाएगा, जिसमें मॉड्यूल और उदाहरण विवरण होंगे।

उदाहरण

एक उदाहरण नीचे चर्चा की गई है -

<script type="text/javascript">     
   const importObj = { 
      module: {} 
   };
   WebAssembly.instantiateStreaming(fetch("findsquare.wasm"), importObj).then(obj => {
      console.log(obj); 
   }); 
</script>

जब आप इसे ब्राउज़र में परीक्षण करेंगे, तो आपको एक त्रुटि दिखाई देगी -

अपने सर्वर के अंत में इसे काम करने के लिए, आपको माइम प्रकार के एप्लिकेशन को जोड़ना होगा / wasm या फिर WebAssembly.instantiate (arraybuffer, importObject) का उपयोग करना होगा।