تولید کد
در علوم رایانه، تولید کد فرایندی است که طی آن، تولید کننده کد یک مترجم، برخی نمایش میانی کد منبع را به یک فرم تبدیل میکند (به طور مثال، زبان ماشین) که میتواند به آسانی توسط ماشین اجرا شود. مترجم های سطح بالا معمولاً چندین گذر بر فرم های میانی انجام می دهند. این فرایند چند مرحله ای به خاطر اینکه الگوریتم های بسیاری برای بهینه سازی کد راحتترند در آن واحد اعمال شوند، یا به خاطر اینکه ورودی یک بهینه سازی بستگی به فرایند کامل شده، اجرا شده توسط بهینه سازی دیگری دارد، استفاده می شود. این بهینه سازی، همچنین ایجاد یک مترجم واحد را که میتواند چندین ساختار را هدف قرار دهد را تسهیل می کند، که فقط آخرین مرحله تولید کد لازم است از هدفی به هدف دیگر تغییر کند. ورودی مولد کد، معمولاً شامل یک درخت تجزیه یا یک درخت نحو انتزاعی است. درخت به یک دنباله خطی از فرمان ها، معمولاً در یک زبان متوسط مثل کد سه آدرسه، تبدیل می شود. مراحل بعد از ترجمه، ممکن یا ناممکن است به عنوان "تولید کد"، بسته به اینکه آیا مستلزم یک تغییر قابل توجه در نمایش برنامه است، اشاره می شود.
وظایف عمده در تولید کد
[ویرایش]به علاوهٔ تبدیل ابتدایی از یک نمایش میانی به یک دنباله خطی از فرامین ماشین، یک مولد کد معمولی سعی میکند کد تولید شده را به نحوی بهینه کند. وظایفی که معمولاً قسمتی از فاز مولد کد یک مترجم سطح بالا است، شامل موارد زیر است:
- انتخاب فرمان: کدام فرامین استفاده شوند.
- زمانبندی فرمان: در کدام دستور، آن فرامین قرار داده شوند. زمانبندی، یک بهینه سازی سرعت است که میتواند تأثیر بحرانی بر ماشینهای خط لوله داشته باشند.
- تخصیص ثبات: تخصیص متغیرها به ثباتهای پردازنده.
- اشکال زدایی تولید کد دادهها اگر لازم باشد، از اینرو کد میتواند اشکال زدایی شود.
انتخاب فرمان، معمولاً با انجام دادن پیمایش بازگشتی درخت بر درخت نحو انتزاعی، مطابق پیکربندی بخصوص درخت مقابل الگوها، انجام میشود؛ برای مثال، درخت ((W := ADD(X,MUL(Y,Z
ممکن است به یک دنباله درختی از فرامین توسط تولید کردن بازگشتی دنبالههایی برای t1 := X
و (t2 := MUL(Y,Z
و بعد بیرون دادن فرمان ADD w, t1, t2
مبدل شود.
در یک مترجم که از یک زبان متوسط استفاده میکند، ممکن است دو مرحله انتخاب فرمان وجود داشته باشد. یکی برای تبدیل درخت تجزیه به کد میانی، و فاز دوم که خیلی بعدتر، کد میانی را به فرامین از مجموعه فرامین ماشین هدف تبدیل میکند. این فاز دوم، درخت پیمایش لازم ندارد. میتواند بهطور خطی انجام شود و معمولاً درگیر یک جایگزینی سادهٔ عملیات زبان متوسط با شناسندههای مربوطه است. هرچند، اگر مترجم در واقع یک مترجم زبان است، آنگاه فاز دوم تولید کد، درگیر ساختن یک درخت از کد میانی خطی است.
زمان اجرای تولید کد
[ویرایش]وقتی تولید کد در زمان اجرا اتفاق می افتد، مثلاً در ترجمۀ بموقع، مهم است که تمام فرایند با رعایت مقدار فضا و زمان، کافی باشد. برای مثال، وقتی عبارات منظم تفسیر شده اند و برای تولید کد در زمان اجرا استفاده می شوند، یک ماشین حالت متناهی غیرقطعی، اغلب به جای ماشین قطعی تولید می شود. زیرا معمولاً غیرقطعی، سریعتر ایجاد میشود و فضای حافظه کمتری از قطعی اشغال می کند. بااینکه به طور کلی کد کافی کمتری تولید می کند، تولید کد بموقع میتواند از شکل دادن اطلاعات که فقط در زمان اجرا در دسترس است، فایده ببرد.
منابع
[ویرایش]مشارکتکنندگان ویکیپدیا. «(Code generation (compiler». در دانشنامهٔ ویکیپدیای انگلیسی.