پی سی مرورگر

.ما راز یک مرورگر سریع و ایمن را می‌دانیم

اتحاد گوگل، اپل، مایکروسافت و موزیلا برای افزایش سرعت مرورگرهای وب

Admin9 فوریه 2016 اپرا اخبار اپرا اخبار اینترنت اکسپلورر اخبار فایرفاکس اخبار گوگل کروم اینترنت اکسپلورر فایرفاکس گوگل کروم

google-apple-microsoft-corporation-mozilla

مهندسان شرکت‌های گوگل، مایکروسافت، اپل و موزیلا گرد هم آمدند تا 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 و… اشاره کرد.

ByteCode

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

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

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

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

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

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

WebAssembly

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

wasm-asm.js-bytecode-machinecode

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

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

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

webassembly-fastest-browser

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

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

 

 

 

 

 

منبع

 

مرجع دانلود مرورگر و افزونه حقوق مطالب، تصاوير و طرح قالب براي سايت p30mororgar محفوظ است.
.Copyright © 2012-2017 p30mororgar.ir All rights reserved
پي‌سي‌مرورگر حامي خليج فارس