קוד נקי
בפיתוח תוכנה קוד נקי (באנגלית clean code) הוא קוד שקל לקרוא, להבין ולתחזק. קוד נקי כתוב בצורה פשוטה ותמציתית, לפי סדרה של מוסכמות שמקלות על הקריאה ועל המעקב.
המונח הפך לפופולרי בעקבות רוברט ססיל מרטין (אנ'), שכתב את הספר "Clean Code: A Handbook of Agile Software Craftsmanship" בשנת 2008. בספר זה, הוא הציג סדרה של עקרונות ושיטות עבודה מומלצות לכתיבת קוד נקי, כמו מתן שמות משמעותיים למשתנים, פונקציות קצרות, הערות ברורות ופורמט עקבי.[1]
הגדרה לא רשמית שטבע מרטין פאולר היא: כל טיפש יכול לכתוב קוד שמחשב יכול להבין, מתכנתים טובים כותבים קוד שבני אדם יכולים להבין.[2]
יתרונות
[עריכת קוד מקור | עריכה]- קריאה ותחזוקה: קוד נקי מקל על קריאת, הבנת ושינוי הקוד. כתיבת קוד קריא מפחיתה את הזמן הדרוש לתפיסת הפונקציונליות של הקוד, מה שמוביל לזמני פיתוח מהירים יותר.
- שיתוף פעולה בצוות: קוד ברור ועקבי מקל על תקשורת ושיתוף פעולה בין חברי הצוות. על ידי הקפדה על מוסכמות קידוד וכתיבת קוד קריא, מפתחים מבינים בקלות זה את עבודתו של זה ומשתפים פעולה בצורה יעילה יותר.
- איתור באגים ופתרון בעיות: קוד נקי כתוב בבהירות ובפשטות, מה שמקל על איתור והבנת חלקים ספציפיים של בסיס הקוד. מבנה ברור, שמות משתנים משמעותיים ופונקציות מוגדרות היטב מקלים על זיהוי ופתרון בעיות.
- איכות ואמינות משופרים: קוד נקי מקטין את הסיכון לשגיאות, מה שמוביל לתוכנה איכותית ואמינה יותר בהמשך.[1]
עקרונות ה-TED
[עריכת קוד מקור | עריכה]Terse - תמצות
[עריכת קוד מקור | עריכה]הקפדה על אורך קוד קצר ומתומצת. יש לחסוך במשתנים שאינם שימושיים בקוד או כאלו שאפשר להמיר אותם במשתנים קיימים או קלים להשגה.
לדוגמה, במקום לכתוב:
int users_count = users_list.size();
if (users_count == 0) {
// do something
}
נעדיף:
if (users_list.isEmpty()) {
// do something
}
Expressive – ביטוי הצורך באופן מדויק וברור
[עריכת קוד מקור | עריכה]יש להסביר באופן המדויק ביותר מה הקוד עושה, ולכן:
- יש להעדיף שמות כלליים שישמשו לטווח רחוק (לדוגמה: אין להוסיף לשם המשתנה את הסוג שלו).
- יש להימנע משמות בעלי משמעות כפולה או רחבה.
- אין לכלול מספר בשם המשתנה, כיוון שלא ברור מה המספר אמור לבטא.
- יש שממליצים לפתוח את כל שמות הפונקציות באחד מהשלושה is,get,do:
- is_XXX - הפונקציה תחזיר ערך בוליאני
- get_XXX - הפונקציה תחזיר ערך כלשהו
- do_XXX - הפונקציה תבצע פעולה מסוימת בלי להחזיר ערך
Do one thing - עשה דבר אחד בכל פעם
[עריכת קוד מקור | עריכה]כל שורת קוד או פונקציה אמורה לבצע פעולה אחת בלבד.
קישורים חיצוניים
[עריכת קוד מקור | עריכה]- Wojtek Lukaszuk, Summary of 'Clean code' by Robert C. Martin, GitHub, 9 באוקטובר 2016
- Ernan, CLEAN CODE - כתיבת קוד שגם בני אדם יכולים לקרוא - Design for Living, באתר ארנן מייסלס, 28 ביוני 2021
- James Samuel, Awesome Clean Code Resources, GitHub, 12 בדצמבר 2017
הערות שוליים
[עריכת קוד מקור | עריכה]- ^ 1 2 What Is Clean Code? A Guide to Principles and Best Practices, blog.codacy.com, 19 בדצמבר 2023
- ^ Digitilizeweb, Any fool can write code that a computer can understand. Good programmers write code that humans can understand — Martin Fowler, Medium, 9 בספטמבר 2023