You are not allowed to perform this action
طراحی کامپایلرها
Compiler Design
مقطع: کارشناسی | گرایش: نرمافزار |
نوع درس: نظری | تعداد واحد: ۳ |
پیشنیاز: ساختمان دادهها و الگوریتمها | همنیاز: – |
هدف کلی
هدف این درس آشنایی دانشجویان با مراحل ساخت کامپایلر برای تبدیل کد برنامه به کد نهایی است. همچنین دانشجویان با قابلیتهای مختلف زبانهای برنامهنویسی و تاریخچه و چگونگی پیادهسازی آنها نیز آشنا خواهند شد. این درس به دانشجویان کمک خواهد کرد تا برای زبان طراحی شده مبتنی بر کاربرد مد نظر خود، کامپایلر آن را تولید کنند. همچنین به ابزار(های) موجود برای تولید خودکار کامپایلر و روش به کارگرفته شده در آن(ها) پرداخته میشود.
سرفصلها
- مقدمه
- انواع مترجم زبانها و تفاوت آنها
- آشنایی سطح بالا با اجزای کامپایلر و وظیفه آنها
- تحلیلگر لغوی/ واژهیاب
- زبانهای منظم
- رفع خطای لغوی
- تحلیلگر نحوی/پارسر
- پارسر پایینگرد بازگشتی غیرپیشگو
- LL (k)
- اصلاح خطای پارس
- ابزار ANTLR
- تولید درخت انتزاعی نحو حین پارس
- تعریف و ترجمه هدایت شده با نحو
- خصیصههای موروثی و ترکیبی
- انواع نمایش میانی کد
- تحلیلگر معنایی
- تحلیل نام: مدیریت گستره (scope)، تحلیل ایستا/پویای نام، قوانین تحلیل نام ایستا
- جدول علائم، رفع خطای تحلیل نام مفاهیم و گستره آن
- تحلیل گونه (type): بررسی گونه ایستا/ پویا، قوانین تحلیل گونه، Subtyping، رفع خطای گونه
- تولید کد براساس مدل ماشین پشته و مدل ماشین RISC
- مروری بر دستورات ماشین مقصد
- تولید کد عبارتهای ریاضی و دستورات کنترلی
- تولید کد بهینه
- مدیریت محیط زمان اجرای برنامه
- مدیریت heap و پشته
- طراحی رکورد فعالیت
- بهینهسازی محلی و سراسری
- تخصیص رجیستر
- زبالهروبی (اختیاری)
ارزیابی پیشنهادی
- آزمون میانترم: ۳۰٪
- آزمون پایانترم: ۴۰٪
- پروژهی عملی: ۲۰٪
- کوئیزها و تمرینات: ۱۰٪
منابع پیشنهادی
- A. W. Appel and J. Palsberg. Modern Compiler Implementation in Java. 2nd Edition, Cambridge University press, 2002
- A. V. Aho, M. S. Lam, R. Sethi, and J. D. Ullman. Compilers: Principles, Techniques, and Tools. 2nd Edition, Addison Wesley, 2007.
- K. D. Cooper and L. Torczon. Engineering a Compiler. 3rd Edition, Elsevier, 2022.