پرش به محتوا

بهینه‌ساز آبجکت کد

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

بهینه‌ساز کد هدف (آبجکت کد)، که گاهی اوقات به عنوان بهینه‌ساز پست پاس نیز شناخته می‌شود یا برای بخشهای کوچکی از کد، بهینه‌ساز peephole نامیده می‌شود، خروجی را از مرحله کامپایل زبان منبع - کد هدف (آبجکت کد) یا فایل باینری - می‌گیرد و سعی می‌کند بخشهای قابل شناسایی کد را با کد جایگزینی که از نظر الگوریتمی کارآمدتر باشد، جایگزین کند (که معمولاً سرعت بهبود می‌یابد).

نمونه‌ها[ویرایش]

  • " بهینه‌ساز باینری اتوماتیک IBM برای z / OS[۱] (ABO) در سال ۲۰۱۵ به عنوان یک فناوری پیشرفته که برای بهینه‌سازی عملکرد برنامه‌های COBOL در بزرگ‌رایانه‌های IBM Z[۲] بدون نیاز به کامپایل دوباره سورس کد طراحی شده‌است، معرفی شد. این بهینه‌ساز از تکنولوژی بهینه‌سازی پیشرفته موجود در آخرین Enterprise COBOL استفاده می‌کند.[۳] ABO باینری‌های کامپایل شده را بدون تأثیر بر منطق برنامه بهینه می‌کند. در نتیجه، برنامه سریعتر اجرا می‌شود اما رفتار بدون تغییر باقی می‌ماند بنابراین تلاش برای تست کاهش می‌یابد. کاربران معمولاً وقتی که به یک کامپایلر جدید یا سطح‌های سخت‌افزار IBM Z ارتقاء می‌دهند ۱۰۰ درصد از کد خود را کامپایل مجدد نمی‌کنند، در نتیجه کدی که مجدد کامپایل نشده‌است قادر به استفاده از مزیت‌های ویژگی‌های موجود در سخت‌افزار جدید IBM Z نخواهد بود. اکنون با استفاده از ABO، کابران یک گزینه دیگر برای کاهش استفاده از CPU و هزینه‌های عملیاتی برنامه‌های بیزینسی و حیاتی COBOL خود دارند. شما می‌توانید بدون نصب ABO روی سیستم خود و از طریق سرویس ابری تست بهبود یافته ABO[۴] آنرا امتحان کنید.
  • اولین "COBOL Optimizer" توسط شرکت Capex در اواسط دهه ۱۹۷۰ برای COBOL ساخته شد. در این حالت، این نوع بهینه‌ساز به دانش "ضعف" در کامپایلر استاندارد IBM COBOL بستگی داشت و در واقع بخشهای کد شی را با کد کارآمدتر جایگزین (یا وصله) کرد. کد جایگزین ممکن است به عنوان مثال جایگزین جستجوی جدول خطی با جستجوی دودویی شود یا گاهی اوقات به راحتی یک دستورالعمل نسبتاً کند را با یک دستورالعمل سریعتر شناخته شده جایگزین کند که از نظر عملکرد در کانتکست آن معادل است. این تکنیک اکنون به عنوان کاهش قدرت شناخته می‌شود. به عنوان مثال، در سخت‌افزار IBM / 360، دستورالعمل CLI بسته به مدل خاص، بین دو تا ۵ برابر سریعتر از دستورالعمل CLC برای مقایسه تک بایت بود.[۵][۶]

مزایا[ویرایش]

مزیت اصلی بهینه‌سازی مجدد برنامه‌های موجود این بود که می‌توان موجودی برنامه‌های مشتری از قبل کامپایل شده (آبجکت کد) را تقریباً بلافاصله با حداقل تلاش بهبود بخشید که کاهش منابع CPU با هزینه ثابت (قیمت نرم‌افزار اختصاصی) را در پی دارد. یک نقطه ضعف این بود که انتشار جدید COBOL، به عنوان مثال، نیاز به نگهداری بهینه‌ساز دارد تا بتواند الگوریتم‌های COBOL داخلی را که احتمالاً تغییر کرده‌اند، تأمین کند. با این حال، از آنجا که انتشار جدید کامپایلرهای COBOL غالباً با به روز رسانی‌های سخت‌افزاری همزمان می‌شود، سخت‌افزار سریع تر معمولاً بیش از این جبران کننده برنامه‌های کاربردی است که به نسخه‌های از پیش بهینه شده آنها بازمی‌گردند (تا زمانی که یک بهینه‌ساز پشتیبانی منتشر شود).

بهینه‌سازهای دیگر[ویرایش]

برخی از بهینه‌سازهای باینری فشرده سازی اجرایی را انجام می‌دهند، که با استفاده از تکنیک‌های عمومی فشرده سازی داده‌ها اندازه فایل‌های باینری را درجهت کاهش نیازهای فضای ذخیره‌سازی و زمان بارگیری و جابجایی، کاهش می‌دهند اما در بهبود عملکرد زمان اجرا اثری ندارند. تلفیق واقعی ماژول‌های کتابخانه تکراری نیز می‌تواند حافظه را کاهش دهد.

برخی از بهینه‌سازهای باینری از معیارهای زمان اجرا (پروفایلینگ) برای بهبود عملکرد از طریق تکنیک‌های مشابه کامپایلرهای JIT استفاده می‌کنند.

توسعه‌های اخیر[ویرایش]

بسیاری از «بهینه سازهای باینری» توسعه داده شده اخیر برای سیستم عامل‌های مختلف، که برخی ادعای نوآوری دارند، اما با این وجود، اساساً از همان روش‌های توصیف شده در بالا (یا مشابه) استفاده می‌کنند، عبارتند از:

  • بهینه‌ساز باینری اتوماتیک IBM برای z/OS (ABO) (2015)[۷]
  • بهینه‌ساز باینری اتوماتیک IBM برای z/OS (ABO) سرویس امتحان ابری (۲۰۲۰)[۸]
  • بهینه‌ساز کد باینری Sun Studio[۹] - که از قبل به فاز پروفایل نیاز دارد
  • طراحی و مهندسی یک بهینه‌ساز باینری پویا - از مرکز تحقیق T.J. Watson - IBM (فوریه 2005)[۱۰][۱۱]
  • QuaC: بهینه‌سازی باینری برای تولید سریع کد اجرا در C[۱۲] - (که به نظر می‌رسد شامل برخی از عناصر JIT است)
  • DynamoRIO
  • COBRA: یک چارچوب بهینه‌سازی باینری تطبیقی برای برنامه‌های چند رشته‌ای
  • Spike Executable Optimizer (هسته یونیکس)[۱۳]
  • "SOLAR" بهینه‌سازی نرم‌افزار در زمان اتصال و زمان اجرا

صفحات مرتبط[ویرایش]

منابع[ویرایش]

  1. https://www.ibm.com/products/automatic-binary-optimizer-zos
  2. https://www.ibm.com/it-infrastructure/z
  3. https://www.ibm.com/us-en/marketplace/ibm-cobol
  4. https://optimizer.ibm.com
  5. http://www.bitsavers.org/pdf/ibm/360/A22_6825-1_360instrTiming.pdf
  6. http://portal.acm.org/citation.cfm?id=358732&dl=GUIDE&dl=ACM
  7. https://www.ibm.com/products/automatic-binary-optimizer-zos
  8. https://optimizer.ibm.com
  9. http://developers.sun.com/solaris/articles/binopt.html
  10. Duesterwald, E. (2005). "Design and Engineering of a Dynamic Binary Optimizer". Proceedings of the IEEE. 93 (2): 436–448. doi:10.1109/JPROC.2004.840302.
  11. http://portal.acm.org/citation.cfm?id=1254810.1254831
  12. http://www.eecs.berkeley.edu/Pubs/TechRpts/1994/CSD-94-792.pdf
  13. «نسخه آرشیو شده» (PDF). بایگانی‌شده از اصلی (PDF) در 11 سپتامبر 2010. دریافت‌شده در 18 اكتبر 2020. تاریخ وارد شده در |بازبینی= را بررسی کنید (کمک)