همکاری برای طراحی WebAssembly
اتحاد گوگل، مایکروسافت و موزیلا برای افزایش سرعت مرورگرهای وب
مهندسان شرکت‌های گوگل، مایکروسافت، اپل و موزیلا گرد هم آمدند تا WebAssembly که به اختصار wasm خوانده می‌شود را طراحی کنند. یک بایت‌کد (bytecode) ویژه که در آینده مورد استفاده مرورگرها قرار خواهد گرفت و ادعا می‌کند کارایی را به میزان 20 برابر سریع‌تر خواهد کرد.

ByteCode چیست؟

ByteCode که به‌نام کد قابل حمل (Portable code) یا به‌اختصار p-code نیز نامیده می‌شود، شکلی از مجموعه دستورالعمل‌ها (Instruction set) است که برای اجرای مؤثر توسط یک مفسر نرم‌افزار طراحی شده‌اند. برعکس کدهای منبع (Source code) که به صورت قابل فهم انسانی هستند، بایت‌کدها از کدهای عددی فشرده، ثابت‌ها و ارجاعات (معمولا آدرس‌های عددی) ساخته شده‌اند که نتیجه تجزیه و تحلیل‌های معنایی اشیایی نظیر نوع‌ها، دامنه و اشیاء تودرتو و داخلی یک برنامه‌ را کدگذاری یا به عبارت دقیق‌تر رمزنگاری (Encode) می‌کنند. از این رو کارایی خیلی بهتری نسبت به ترجمه مستقیم کد اصلی خواهند داشت. یک برنامه بایت‌کد ممکن است فرآیند تجزیه و اجرای مستقیم دستورالعمل‌ها را در یک زمان انجام دهد. این نوع از مفسران بایت‌کدها بسیار قابل حمل هستند. بعضی سیستم‌ها از آن‌ها به نام مترجمان پویا یا کامپایلرهای just in time م(JIT) نام می‌برند. از جمله بایت‌کدهای معروفی که امروزه مورد استفاده قرار می‌گیرند، می‌توان به ActionScript، Byte Code Engineering Library، CLISP، Common Intermediate Language که توسط محیط زمان اجرای CLR اجرا شده و توسط زبان‌های برنامه‌نویسی دات‌نت همچون سی‌شارپ مورد استفاده قرار می‌گیرند، Emacs، Java bytecode و.... اشاره کرد.

جاوااسکرپیت دوست‌داشتنی

برای سال‌های متمادی موتورهای جاوااسکرپیت کانون توجه توسعه‌دهندگان مرورگرها قرار داشتند. همین موضوع باعث شده بود تا محصولات سازندگان نه تنها روند رو به رشدی داشته باشد بلکه عملکرد و بهره‌وری آن‌ها به میزان قابل توجهی بهبود یابد. (javascript engine یک ماشین مجازی است که برای ترجمه و اجرای دستورات جاوااسکرپیت مورد استفاده قرار می‌گیرد. البته موتورهای جاوااسکرپیت کارکردهای مختلفی دارند و به طور گسترده توسط مرورگرهای وب مورد استفاده قرار می‌گیرند.) کامپایل پویا که از آن به‌نام کامپایل درجا نیز یاد می‌شود، برای تبدیل کدهای جاوااسکرپیت به دستورالعمل‌هایی مورد استفاده قرار می‌گیرد که به طور مستقیم روی پردازشگر اجرا شده و به لحاظ سرعت دستاوردهای مهمی را به‌همراه می‌آورد. با وجود این پیشرفت‌ها هنوز یک پرسش وجود دارد: "چرا جاوا اسکرپیت؟". البته به‌کارگیری جاوااسکرپیت هزینه‌هایی را نیز تحمیل می‌کند. مرورگرها باید کدهای زبانی که بر پایه متن‌های قابل فهم انسانی و نه ماشینی است را دریافت کرده، آن‌ها را خوانده و ترجمه کنند. حتی ساختار خود جاوااسکرپیت به‌گونه‌ای است که دارای تعدادی ویژگی نه چندان مطلوب است که همین موضوع بر کارایی آن تأثیر نامطلوب می‌گذارد. به طور مثال، روشی که در آن یک متغیر در شرایط مختلف می‌تواند انواع متنوعی از داده‌ها همچون اعداد، رشته‌ها یا بخشی از HTML ترجمه شده را در خود جای دهد، اما یک کامپایلر JIT ممکن است توانایی ترجمه بهینه‌سازی شده آن‌را به‌گونه‌ای که لازم است نداشته باشد یا توانایی ویرایش رفتار اشیاء از پیش ساخته شده شبیه آرایه‌ها که ممکن است دردسرهایی را به‌وجود آورد، نمونه‌ای از این معایب به‌شمار می‌رود. اما جاوااسکرپیت مزیت‌های کاملا مشخصی نیز دارد. برنامه‌های جاوااسکرپیت در محیط sandbox قرار دارند؛ به این معنی که به غیر از باگ‌های مرورگرها، برنامه‌های جاوااسکرپیت نمی‌توانند فراتر از محدوده مرورگر برای دسترسی به اطلاعات حساس یا نصب نرم‌افزارهای مخرب اقدام کنند. جاوااسکرپیت همچنین مستقل از پردازشگر است، در نتیجه اسکرپیت‌ها به همان  خوبی که روی یک کامپیوتر شخصی با معماری x86 اجرا می‌شوند روی گوشی‌های هوشمند مجهز به پردازنده آرم نیز اجرا می‌شوند. همین نکات مثبت باعث می‌شود تا مزیت‌های جاوااسکرپیت بدون آن که جنبه‌های منفی آن به چشم آیند مورد توجه قرار گیرند.

تقاضا برای بهکارگیری بایتکدها آغاز میشود

به این ترتیب فشارهایی برای استفاده از سیستم‌های بایت‌کد در مرورگرها به‌وجود آمد. بر همین اساس مایکروسافت و سان (در حال حاضر اوراکل) این موضوع را با دات‌نت و جاوا حل کردند اما این سیستم‌ها به جای آن‌که بر موتور رندر مرورگرها و به صورت یکپارچه با جاوااسکرپیت استوار باشند، بر افزونه‌ها متکی بودند. برنامه‌های جاوا اسکریپت به طور مستقیم توانایی دستکاری اشیاء HTML را دارند اما در عوض افزونه‌ها دنیای خاص خود را دارند.  شرکت‌های دیگری همچون گوگل سعی کردند مجموعه‌ای از سیستم‌ها را برای مرورگرها توسعه داده و اتکا بر جاوااسکرپیت را کم کنند. Native Clinet که برنامه‌های بر پایه معماری x86 یا آرم را در یک محیط ایمن سندباکس اجرا می‌کرد یا Portable Native Client م(PNaCl) نیز همین کار را انجام می‌داد اما از نوعی بایت‌کد به جای استفاده از کد آرم یا x86 استفاده می‌کرد. در حالی‌که گوگل سعی کرد کمپینی را برای استفاده از ابداعات خود به راه اندازد، اما سازندگان مرورگرها از پذیرفتن ‌آنها طفره رفتند. در طول این سال‌ها راهکارهای مختلفی ارائه شدند و همچون نمونه‌هایی که به آن‌ها اشاره کردیم توسط شرکت‌های بزرگ مطرح شدند اما یک اجماع واحد روی آن‌ها به وجود نیامد. مردم خواستار یک بایت‌کد ویژه برای مرورگرها بودند که مزایایی که در گذشته وجود نداشت را در بر گرفته و ایرادات قبلی را نداشته باشد.

WebAssembly به میدان وارد می‌شود

وب‌اسمبلی، پروژه‌ای جدید بوده که کار روی آن توسط موزیلا، مایکروسافت، گوگل و اپل در حال انجام است و هدف از آن تولید یک بایت‌کد برای وب است که به درخواست‌ها واکنش نشان دهد.

WebAssembly که به اختصار wasm نامیده می‌شود با هدف ارائه بایت‌کدی قابل حمل که بر روند دانلود و بارگذاری تأثیرگذار بوده و کارآمدتر از جاوا اسکرپیت یا asm.js باشد، در حال طراحی است.  WebAssembly پروژه‌ای است که اکنون روی گیت‌هاب میزبانی می‌شود و برای ساخت یک‌ بایت‌کد ماشینی که توانایی خواندن مجموعه‌ای از دستورالعمل‌ها را برای مرورگرها راحت کرده به‌طوری که توانایی بارگذاری زبان‌های سطح بالا را داشته باشند باعث به وجود آوردن کارایی محسوسی برای مرورگرهای دسکتاپ و موبایل خواهد شد به طوری‌که امکان تجزیه کامل کدهای منبع یک صفحه وب یا یک برنامه را فراهم می‌کند.

مرورگرها در حال حاضر از جاوااسکرپیت برای تفسیر کدها و فعال‌سازی قابلیت‌هایی نظیر محتوای پویا و فرم‌ها روی سایت‌ها استفاده می‌کنند. هر چند راهکارهایی برای بهبود زمان بارگذاری از طریق asm.js انجام شده است، اما سیستم‌های بایت‌کد محور شبیه به دات‌نت سریع‌تر هستند.

ساختار فعلی وب‌اسمبلی چگونه است؟

طراحی وب‌اسمبلی به‌گونه ای خواهد بود که هم شامل نمادهای دودویی که توسط کامپایلرها تولید می‌شوند و هم شامل متن متناظر که برای نمایش در دیباگرها و برای محیط‌های توسعه مناسب است خواهد بود. نمونه‌های اولیه که تاکنون ارائه شده‌اند از ویژگی‌های هیجان‌برانگیز و کارآمد خبر می‌دهند به‌طوری که آمارها نشان از 20 برابر سریع‌تر بودن تجزیه‌ها نسبت به asm.js حکایت دارند. مهندسانی که در پشت صحنه wasm قرار دارند فراموش نکرده‌اند که جاوا اسکرپیت در همه جا پشتیبانی می‌شود و wasm در حال حاضر در هیچ کجا از جاوااسکرپیت پشتیبانی نمی‌کند. آن‌ها در نظر دارند تا این خلاء را از طریق polyfill یک اسکرپیت جاوااسکرپیت که قادر به تبدیل wasm به asm.js برای مرورگرهایی که به طور محلی از wasm پشتیبانی نمی‌کنند پیاده‌سازی کنند. البته wasm هنوز در مرحله توسعه قرار دارد. هنوز هیچ استانداری در بدنه آن به کار نرفته است و تنها یک گروه غیر رسمی در حال کار روی آن هستند. مشخصات هنوز کامل نشده‌اند و طراحی سطح بالای آن هنوز در مرحله تصمیم‌گیری قرار دارد. اما هر چهار سازنده بزرگ موتور مرورگرها با یکدیگر در حال کار روی آن هستند.

آینده‌ای روشن

آینده wasm باید درخشان باشد و منتقدان جاوااسکریپت که برای مدت‌های طولانی از جاوااسکرپیت ناراضی بوده و شکایت می‌کردند  اکنون به آرزوی خود برای داشتن یک بایت‌کد ویژه خواهند رسید. پیشنهاد این فناوری در قالب یک استاندارد روزگاری در همه مرورگرها پیاده‌سازی خواهد شد. تا زمانی‌که WebAssembly به طور گسترده در دسترس قرار گیرد، ائتلاف توسعه‌دهندگان در حال برنامه‌ریزی برای پر کردن این شکاف با استفاده از JS script هستند که توانایی تبدیل wasm به asm.js را در اختیار مرورگرهایی که هنوز از فرمت جدید پشتیبانی نمی‌کنند قرار ‌دهد.WebAssembly  هنوز تا رسیدن به مرحله نهایی زمان زیادی خواهد داشت: نه مشخصات آن و نه طراحی سطح بالای آن هنوز به پایان نرسیده‌اند. با این حال، با توجه به این‌که توسعه‌دهندگان بزرگ در پشت این پروژه قرار دارند باید در آینده‌ای نزدیک شاهد افق‌های روشنی در این زمینه باشیم.

ماهنامه شبکه را از کجا تهیه کنیم؟
ماهنامه شبکه را می‌توانید از کتابخانه‌های عمومی سراسر کشور و نیز از دکه‌های روزنامه‌فروشی تهیه نمائید.

ثبت اشتراک نسخه کاغذی ماهنامه شبکه     
ثبت اشتراک نسخه آنلاین

 

کتاب الکترونیک +Network راهنمای شبکه‌ها

  • برای دانلود تنها کتاب کامل ترجمه فارسی +Network  اینجا  کلیک کنید.

کتاب الکترونیک دوره مقدماتی آموزش پایتون

  • اگر قصد یادگیری برنامه‌نویسی را دارید ولی هیچ پیش‌زمینه‌ای ندارید اینجا کلیک کنید.

ایسوس

نظر شما چیست؟