he.wikipedia.org

מהדר – ויקיפדיה

  • ️Mon Jul 18 2016

מתוך ויקיפדיה, האנציקלופדיה החופשית

המונח "הידור" מפנה לכאן. לערך העוסק במושג ביהדות, ראו הידור מצווה.

תרשים המתאר פעולת מהדר בעל מספר שפות ומספר יעדים

מְהַדֵּראנגלית: Compiler) הוא תוכנית מחשב המתרגמת משפת מחשב אחת לשפת מחשב אחרת. המהדר הקלאסי מקבל כקלט תוכנית הכתובה בשפה עילית ומתרגם אותה לתוכנית בשפת מכונה. מהדר תואם בדרך כלל לסוג מעבד מסוים בלבד, ולגרסת שפה מסוימת, ותוצריו לא יהיו תואמים למעבד אחר. פעולת המהדר קרויה הידוּר.

המהדר ממיר פקודות משפה המוגדרת על ידי דקדוק אחד לפקודות שמוגדרות על ידי דקדוק אחר. המרה זו בדרך כלל איננה פונקציה חד-חד-ערכית, כלומר את התוצר של מהדר לרוב לא ניתן לתרגם חזרה לקוד המקור: מקודי מקור שונים אפשר להגיע לאותו תוצר סופי.

תהליך בניית תוכנת מחשב מתחלק לשני שלבּים עיקריים - הידור וקישור. המהדר אחראי על תהליך ההידור. בתהליך ההידור ממיר המהדר את הקוד שכתב המתכנת, לשפת מכונה, כך שעבור כל קובץ שעבר הידור נוצר קובץ מקביל בשפת מכונה. קובץ זה מסומן בדרך כלל כקובץ OBJ (או O במהדרים אחרים). תהליך ההידור מורכב ממספר תת-שלבים עיקריים: ניתוח מילולי, ניתוח תחבירי, ניתוח סמנטי, ולבסוף שלב יצירת קוד המכונה.

בתהליך הקישור מקושרים ביחד קבצים אלה לתוצר סופי - תוכנה שניתנת לביצוע במעבד ובמערכת הפעלה מסוימת.

מהדרים של שפות תכנות מסוימות מפיקים קוד למעבד וירטואלי שאינו מיושם באופן ישיר בחומרה. דוגמה לשפות כאלה - ‏Java‏, ‎C#‎ ו-Smalltalk. היתרון בשיטה זו הוא היכולת להריץ את אותו קובץ מהודר במעבדים מסוגים שונים.[1]

מחשבים אינם בעלי בינה ואינם מבצעים דבר פרט למספר מוגבל של פקודות חישוב אלקטרוניות. כל מחשב בנוי על שבב אלקטרוני אחד או יותר הקרוי מעבד המסוגל לקבל בצורה בינארית נתוני קלט, לבצע עליהם פעולה מסוימת ולחשב את הפלט. הכנסת הנתונים והפקודות למעבד מתבצעת בצורה של הכנסת קוד (מספר) של פקודה, יחד עם הנתונים שיעובדו. רצף הפקודות שניתן למעבד נקרא שפת מכונה. אותה שפת מכונה היא התוכנה המורצת במחשב.

בשל הקושי לתכנת את המחשב בשפת מכונה, פותחו עם השנים שפות תכנות מופשטות יותר, הנקראות בשם הקיבוצי שפות עיליות. הדקדוק המגדיר שפה עילית הוא מורכב יותר מדקדוק שפת המכונה, אך עם זאת ברור יותר ומאפשר התייחסות מופשטת יותר להיבטים שונים של החומרה והתוכנה, תחזוקתיות קלה יותר, ופיתוח מהיר יותר.

תפקידו של המהדר, אם כך, הוא להמיר את הדקדוק העילי לדקדוק שפת המכונה. באופן כללי ניתן לומר שככל ששפת התכנות מופשטת יותר, כך על המהדר להיות מותאם ומורכב יותר.

שגיאות זמן הידור הן שם כולל לשגיאות שעל המהדר לזהות כבר בשלב ההידור. שגיאות מסוגים שונים יתגלו בשלבים שונים בזמן ההידור.

תלוי באופי השגיאה, זיהוי שגיאת זמן הידור עלולה לעצור את כל פעולת ההידור, או לאפשר לתהליך להמשיך.

מהדר לעיתים יפיק גם אזהרות על בעיות פוטנציאליות בקוד שלא מונעות את הידורו, אולם פוגעים בקריאות הקוד, כגון חלקים מיותרים שאינם משפיעים כלל על ריצת הקוד.

  1. ^ Chengnian Sun, Vu Le, Qirun Zhang, Zhendong Su, Toward understanding compiler bugs in GCC and LLVM, Proceedings of the 25th International Symposium on Software Testing and Analysis, ISSTA 2016, Association for Computing Machinery, 2016-07-18, עמ' 294–305 doi: 10.1145/2931037.2931074
תחומים במדעי המחשב
יסודות מתמטים לוגיקה מתמטיתתורת הקבוצותתורת המספריםתורת הגרפיםתורת הטיפוסיםתורת הקטגוריותאנליזה נומריתתורת האינפורמציה
תורת החישוביות תורת האוטומטיםתורת הרקורסיהתורת הסיבוכיותמחשוב קוונטי
אלגוריתמים ומבנה נתונים אנליזה של אלגוריתמיםגאומטריה חישובית
שפות תכנות ומהדרים מפרשפרדיגמת תכנות (תכנות פרוצדורליתכנות מונחה עצמיםתכנות פונקציונליתכנות לוגי)
חישוב מבוזר ועיבוד מקבילי עיבוד מקבילימחשוב סריגיבקרת מקביליות
הנדסת תוכנה ניתוח מערכות מידעעיצוב תוכנהתכנות מחשביםשיטות פורמליותבדיקות תוכנהמתודולוגיית פיתוח תוכנה
תקשורת ניתובטופולוגיית רשתקריפטוגרפיה
מסד נתונים מסד נתונים יחסיSQLתנועהאינדקסיםכריית מידעCAP theorem
בינה מלאכותית חשיבה אוטומטיתבלשנות חישוביתראייה ממוחשבתעיבוד שפה טבעיתבינה חישוביתמערכת מומחהלמידה חישוביתרובוטיקה
גרפיקה הדמיה ממוחשבתהנפשה ממוחשבתעיבוד תמונה
שפות פורמליות שפה רגולריתשפה חסרת הקשרשפה תלוית הקשרההיררכיה של חומסקי
שימושים במדע ביואינפורמטיקהמדעים קוגניטיבייםכימיה חישוביתפיזיקה חישוביתאנליזה נומרית