1402/01/04

نوتیف

دنیایی رو به دانش و آگاهی

۲۰ درسی که از بعد از ۱۰ سال توسعه نرم‌افزار آموختم از «آندرج سویک»

1 min read

۲۰ درسی که از بعد از ۱۰ سال توسعه نرم‌افزار آموختم به قلم «Ondrej Sevcik»

  1. فروتن باشید هیچ مهندسی همه چیز رو نمی‌دونه. شما هم همینطور!
  2. فقط یه کاری کنید که درست کار کنه! (و گاهی وقتها یه کاری کنید که سریع کار کنه)
  3. کد رو برای تغییرات بهینه کنید. تکرار کردن کد رو به انتزاع (abstraction) اشتباه ترجیح بدید
  4. همیشه تست بنویسید اگه تست ننویسید یعنی دارید دستی (manual) تست می‌کنید.
  5. ۸۰ درصد از کاربردها (use cases) رو پوشش بدید. هیچوقت نخواهید که مشکلات همه کاربران رو حل کنید
  6. برنامه‌نویسی تابعی (functional) رو ترجیح بدید چون درکش راحت‌تره. اما اگه درک کدتون نیاز به Phd داره احتمالا دارید اشتباه انجامش میدید!
  7. هرچقدر که می‌تونید کد بیشتری حذف کنید
  8. به اندازه کافی خوب، بهتر از عالیه. بهبودهای معنادار رو صرفا به این دلیل که عالی نیستند حذف نکنید
  9. در خلوت انتقاد کنید، در مقابل جمع تشویق کنید
  10. یادداشت بردارید. اگه فکر می‌کنید که یادتون می‌مونه، دارید به خودتون دروغ می‌گید
  11. با کاربران حرف بزنید بهترین نرم‌افزار از زیر دست مهندسانی در میاد که با کاربران‌شون همدلی دارند.
  12. با قصد و نیت یاد بگیرید با داشتن یک هدف واضح و شفاف در مورد اینکه چه چیزی رو و چطور می‌خواهید بهبود بدید، تمرین کنید. (deliberate practice)
  13. زود عمومی‌اش (generalize) نکنید صبر کنید تا نیاز به ۳ بار تکرار کد باشه قبل از اینکه abstract اش کنید (Rule of Three)
  14. پنجره شکسته رو تعمیر کنید اولین ترفند (hack) توی کد منجر به ترفند‌های بعدی میشه و کدتون به سرعت غیر قابل نگهداری میشه.
  15. مشکل رو حل کنید. اصلا مهم نیست تقصیر کی بوده. در حال حاضر اون مشکل، مشکل شماست!
  16. راه حلی رو پیاده کنید که کار می‌کنه، نه اونی که مد روزه. اول با یک تیم کوچیک شروع کنید. اگه کار کرد، گسترشش بدید. اگه نکرد، بریزیدش دور
  17. کار عالی نیازمند استراحت خوبه برای رسیدن به کارایی بالا به خودتون استراحت بدید. دونده‌های سرعت حرفه‌ای هم همیشه در حال دویدن نیستند.
  18. گامهای کوچک بردارید بازنویسی‌های بزرگ کار نمی‌کنند چون انگیزه و تمرکزتون رو در طول مسیر از دست می‌دید. به صورت روزانه پروژه‌هاتون رو منتشر (release) کنید. این بهتون اجازه میده هر وقت که خواستید تمرکزتون رو به کارهای دیگه منتقل کنید.
  19. کارهای خوب رو تشویق کنید ما این رو در مورد حیوانات مشاهده کردیم اما روی آدمها هم جواب میده. به جای تنبیه اشتباهات، موفقیت‌های افراد تیم رو تشویق کنید
  20. کد بی‌نقص وجود نداره بهتره این رو به عنوان یک اصل بپذیرید به جای اینکه تلاش کنید یه چیز غیرممکن رو تغییر بدید.

منبع: +

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *