קוד נקי

(הופנה מהדף Clean code)

בפיתוח תוכנה קוד נקי (באנגלית 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 - עשה דבר אחד בכל פעם

עריכה

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

קישורים חיצוניים

עריכה

הערות שוליים

עריכה