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) का उपयोग करना होगा।