کمپائلر میں مرحلے اور پاس کے درمیان فرق

Anonim

فیز بمقابلہ بمقابلہ کمپیکل میں

عام طور پر، کمپائلر کمپیوٹر پروگرام ہے ایک زبان میں لکھی گئی پروگرام، جو ذریعہ زبان کہا جاتا ہے، اور اسے دوسری زبان میں ترجمہ کرتا ہے، جس کو ہدف زبان کہا جاتا ہے. روایتی طور پر، ذریعہ زبان ایک اعلی درجے کی زبان تھی جیسے C ++ اور ہدف زبان کم سطح کی زبان تھی جیسے اسمبلی کی زبان. لہذا، عام طور پر compilers میں مترجمین کے طور پر دیکھا جا سکتا ہے جو ایک زبان سے دوسری زبان میں ترجمہ کرتا ہے. پاس اور مرحلے اکثر دو اصطلاحات ہیں جو اکثر compilers کے ساتھ استعمال کرتے ہیں. ایک کمپائلر کے پاس جانے والے نمبروں کی تعداد یہ ہے کہ یہ ذرائع (یا اس کی نمائندگی کے کچھ شکل) پر چلتا ہے. تعمیراتی سہولت کے حصوں میں ایک کمپائلر ٹوٹا ہوا ہے. ایک مرکب کے اس واحد واحد حصہ کو فون کرنے کے لئے اکثر مرحلے کا استعمال کیا جاتا ہے.

ایک کمپائلر میں کیا پاس ہے؟

compilers کو درجہ بندی کرنے کا ایک معیاری طریقہ "منظور" کی تعداد کی طرف سے ہے. عموما، مجموعی طور پر نسبتا وسائل کا ایک جامع ذریعہ ہے اور ابتدائی طور پر اس طرح کے ایسے پروگرام کو پورا کرنے کے لئے کمپیوٹر کو کافی میموری نہیں ملا جس نے مکمل کام کیا. ابتدائی کمپیوٹرز میں ہارڈویئر وسائل کی اس حد کے باعث، کمپائلر چھوٹے ذیلی پروگراموں میں ٹوٹ گئے تھے جنہوں نے ماخذ کوڈ پر جانے کی طرف سے اس کی جزوی ملازمت (ذریعہ یا اس کے کچھ دوسرے فارم پر "پاس" بنا دیا) اور تجزیہ کا مظاہرہ کیا. تبدیلیوں اور ترجمہ کاموں کو الگ الگ. لہذا، اس درجہ بندی پر منحصر ہے، compilers ایک منظور یا کثیر پاس compilers کے طور پر اشارہ کیا جاتا ہے.

جیسا کہ نام سے پتہ چلتا ہے، ایک پاس ٹریلرز ایک ہی پاس میں مرتب کرتا ہے. ایک پاس پاس کنسلر لکھنے کے لئے آسان ہے اور یہ بھی کثیر پاس موافقت کرنے والے مقابلے میں تیزی سے انجام دیتا ہے. لہذا، اس وقت بھی جب آپ کے ذریعہ وسائل کی حد تھی، زبانوں کو ڈیزائن کیا گیا تھا تاکہ وہ ایک پاس (ای پیسسل) میں مرتب کیا جا سکے. دوسری جانب، ایک عام کثیر پاس کنکولیٹر کئی اہم مراحل سے بنا ہے. پہلا مرحلہ سکینر (لیکسیکل تجزیہ کے طور پر بھی جانا جاتا ہے) ہے. سکینر پروگرام کو پڑھتا ہے اور اسے ٹکنز کی تار میں بدلتا ہے. دوسرا مرحلہ پارسر ہے. یہ ایک پیرس کے درخت (یا ایک خلاصہ نحو درخت) میں ٹوکن کی تار بدل دیتا ہے، جس میں پروگرام کے مصنوعی ساخت پر قبضہ ہوتا ہے. اگلے مرحلے یہ ہے کہ یہ مصنوعی ڈھانچے کے سیمانکس کی وضاحت کرتی ہے. کوڈ اصلاحی مراحل اور حتمی کوڈ نسل مرحلے اس پر عمل کریں.

کمپائلر میں کیا مرحلہ ہے؟

جب آپ کمپائلر تعمیر کے بارے میں بات کرتے ہیں تو یہ اصطلاح مرحلہ آتا ہے. ابتدائی طور پر، compilers ایک سادہ زبان کی تالیف کے لئے ایک شخص کی طرف سے لکھا واحد، monolithic سافٹ ویئر کے ہر سادہ ٹکڑوں تھے. لیکن جب زبان کا ذریعہ کوڈ کا ذریعہ کوڈ پیچیدہ اور بڑا ہو جاتا ہے تو، اس کا مجموعہ ایک سے زیادہ (نسبتا آزاد) مراحل میں ٹوٹ گیا تھا.مختلف مراحل رکھنے کا فائدہ یہ ہے کہ کنسلر کی ترقی ڈویلپرز کی ایک ٹیم کے درمیان تقسیم کیا جا سکتا ہے. اس کے علاوہ، یہ ماڈیولر میں بہتری اور اصلاحات کو بہتر بنانے یا اضافی مراحل (جیسے جیسے مزید اصلاحات) کی طرف سے تبدیل کرنے کی اجازت دے کر دوبارہ استعمال کرنے میں مدد کرتا ہے. مرحلے پر تالیف تقسیم کرنے کے عمل کینیجی میلون یونیورسٹی میں PQCC (پیداوار کوالٹی کمپائلر-کمپائلر پراجیکٹ) کی طرف سے متعارف کرایا گیا. انہوں نے شرائط کے سامنے اختتام، درمیانی اختتام اور پیچھے کے آخر میں متعارف کرایا. زیادہ سے زیادہ compilers کم از کم دو مراحل ہیں. لیکن عام طور پر، آخر کے اختتام اور فرنٹ اختتام ان مرحلے کو خارج کر دیتا ہے.

کمپائلر میں مرحلے اور پاس کے درمیان کیا فرق ہے؟

مرحلہ اور پاس دو شرائط ہیں جس کا استعمال compilers کے علاقے میں ہے. ایک پاس ایک ہی وقت ہے جس کا پتہ چلتا ہے کہ کنسلر اس سے زیادہ گزرتا ہے (ذریعہ جاتا ہے) ذرائع کوڈ کا کوڈ یا اس کی کچھ دوسری نمائندگی. عام طور پر، سب سے زیادہ compilers کم سے کم دو مراحل ہیں جو سامنے کے آخر اور پیچھے کے آخر میں کہتے ہیں، جبکہ وہ یا تو ایک پاس یا کثیر پاس ہوسکتے ہیں. تعمیر کے مطابق compilers کو درجہ بندی کرنے کے لئے مرحلے کا استعمال کیا جاتا ہے، جبکہ وہ کاروائیوں کو درجہ بندی کرنے کے لئے استعمال کیا جاتا ہے کہ وہ کس طرح کام کرتے ہیں.