Facebook Pixel
Searching...
فارسی
EnglishEnglish
EspañolSpanish
简体中文Chinese
FrançaisFrench
DeutschGerman
日本語Japanese
PortuguêsPortuguese
ItalianoItalian
한국어Korean
РусскийRussian
NederlandsDutch
العربيةArabic
PolskiPolish
हिन्दीHindi
Tiếng ViệtVietnamese
SvenskaSwedish
ΕλληνικάGreek
TürkçeTurkish
ไทยThai
ČeštinaCzech
RomânăRomanian
MagyarHungarian
УкраїнськаUkrainian
Bahasa IndonesiaIndonesian
DanskDanish
SuomiFinnish
БългарскиBulgarian
עבריתHebrew
NorskNorwegian
HrvatskiCroatian
CatalàCatalan
SlovenčinaSlovak
LietuviųLithuanian
SlovenščinaSlovenian
СрпскиSerbian
EestiEstonian
LatviešuLatvian
فارسیPersian
മലയാളംMalayalam
தமிழ்Tamil
اردوUrdu
Joel on Software

Joel on Software

توسط Joel Spolsky 2004 362 صفحات
4.12
3k+ امتیازها
گوش دادن

نکات کلیدی

1. کیفیت نرم‌افزار نیازمند آزمایش‌های دقیق و تسترهای متعهد است

برای نسخه‌ی جدید CityDesk، نرم‌افزار مدیریت وب‌سایت که توسط شرکت من Fog Creek Software منتشر شده است، تصمیم گرفتیم همه چیز را به صورت داخلی در UCS-2 (یونی‌کد ۲ بایتی) انجام دهیم، که همان نوع رشته‌ی بومی در Visual Basic، COM و Windows NT/2000/XP است.

آزمایش جامع ضروری است. آزمایش‌های دقیق، شامل تست‌های کاربری و گزارش خودکار خرابی، برای اطمینان از کیفیت نرم‌افزار ضروری است. تسترهای متعهد، ایده‌آل این است که به ازای هر دو برنامه‌نویس یک تستر وجود داشته باشد، باید بخشی جدایی‌ناپذیر از تیم توسعه باشند. نقش آن‌ها شناسایی باگ‌ها، اعتبارسنجی عملکرد و اطمینان از تجربه‌ی کاربری روان است.

گزارش خودکار خرابی ارزشمند است. پیاده‌سازی سیستم‌هایی که به‌طور خودکار خرابی‌ها را از کاربران در میدان جمع‌آوری و گزارش می‌کنند، می‌تواند داده‌های ارزشمندی برای بهبود کیفیت نرم‌افزار فراهم کند. این رویکرد به توسعه‌دهندگان اجازه می‌دهد تا مشکلاتی را که ممکن است در طول آزمایش‌های داخلی آشکار نشوند، شناسایی و رفع کنند.

مثال پیاده‌سازی یونی‌کد:

  • انتخاب UCS-2 (یونی‌کد ۲ بایتی) برای عملیات داخلی
  • هم‌راستا با نوع رشته‌ی بومی Visual Basic، COM و Windows NT/2000/XP
  • تبدیل به کدگذاری UTF-8 برای انتشار وب
  • منجر به پشتیبانی بی‌نقص از ۲۹ نسخه‌ی زبانی Joel on Software شد

2. مدیریت پروژه‌ی مؤثر نیازمند مشخصات دقیق و انعطاف‌پذیر است

اگر در حال نوشتن برنامه‌ای هستید، مثلاً یک پردازشگر کلمه، و می‌خواهید منویی نمایش دهید یا فایلی بنویسید، باید از سیستم‌عامل بخواهید که این کار را برای شما انجام دهد، با استفاده از مجموعه‌ای بسیار خاص از فراخوانی‌های تابع که در هر سیستم‌عامل متفاوت است.

مشخصات دقیق ضروری است. نوشتن مشخصات جامع و دقیق قبل از شروع کدنویسی برای مدیریت پروژه‌ی مؤثر ضروری است. این مشخصات باید عملکرد مورد نظر، رابط کاربری و نیازهای فنی نرم‌افزار را مشخص کنند.

انعطاف‌پذیری کلیدی است. در حالی که مشخصات نقشه‌ی راه را فراهم می‌کنند، باید اسنادی زنده باشند که بتوانند با پیشرفت پروژه به‌روزرسانی شوند. بازبینی و تجدیدنظر منظم در مشخصات اطمینان می‌دهد که آن‌ها مرتبط و هم‌راستا با اهداف پروژه باقی می‌مانند.

عناصر کلیدی مشخصات مؤثر:

  • توصیف واضح ویژگی‌ها و عملکرد
  • ماکاپ‌ها یا وایرفریم‌های رابط کاربری
  • نیازها و محدودیت‌های فنی
  • جدول زمانی و نقاط عطف
  • تخصیص منابع
  • ارزیابی ریسک و استراتژی‌های کاهش

3. استخدام و پرورش استعدادهای برتر برای موفقیت توسعه‌ی نرم‌افزار حیاتی است

شرکت‌های هوشمند سعی می‌کنند مکمل‌های محصولات خود را به کالا تبدیل کنند.

استراتژی استخدام حیاتی است. جذب و نگه‌داشتن استعدادهای برتر برای موفقیت توسعه‌ی نرم‌افزار ضروری است. شرکت‌ها باید بر استخدام افراد باهوش و انگیزه‌دار که می‌توانند با فناوری‌های جدید سازگار شوند و مشکلات پیچیده را حل کنند، تمرکز کنند.

یادگیری مداوم حیاتی است. تشویق به فرهنگ یادگیری و بهبود مداوم به حفظ تیم توسعه در حالت تیز و به‌روز با آخرین فناوری‌ها و بهترین شیوه‌ها کمک می‌کند.

استراتژی‌های کلیدی استخدام و پرورش استعداد:

  • فرآیندهای مصاحبه‌ی دقیق که مهارت‌های حل مسئله را آزمایش می‌کنند
  • بسته‌های جبران رقابتی
  • فرصت‌های توسعه‌ی حرفه‌ای و رشد
  • ایجاد محیط کاری مثبت که خلاقیت و نوآوری را تقویت کند
  • بازبینی‌های منظم کد و جلسات اشتراک دانش
  • تشویق به مشارکت در پروژه‌های منبع باز یا کنفرانس‌های صنعتی

4. طراحی رابط کاربری باید اولویت را به سادگی و تجربه‌ی کاربری بدهد

تست کاربری راهرو جایی است که شما نفر بعدی که از راهرو عبور می‌کند را می‌گیرید و او را مجبور می‌کنید کدی که تازه نوشته‌اید را امتحان کند.

سادگی در طراحی رابط کاربری کلیدی است. رابط‌های کاربری باید شهودی و آسان برای استفاده باشند و تجربه‌ی کاربری را بر ویژگی‌های پیچیده اولویت دهند. تست‌های کاربری منظم، از جمله تست‌های غیررسمی "راهرو"، می‌توانند بینش‌های ارزشمندی در مورد نحوه‌ی تعامل کاربران با نرم‌افزار ارائه دهند.

فرآیند طراحی تکراری ضروری است. طراحی رابط کاربری باید یک فرآیند تکراری باشد، با بازخورد کاربر مکرر که در نسخه‌های بعدی گنجانده می‌شود. این رویکرد کمک می‌کند تا محصول نهایی نیازها و انتظارات کاربران را برآورده کند.

استراتژی‌های مؤثر طراحی رابط کاربری:

  • انجام تست‌های کاربری منظم با گروه‌های کاربری متنوع
  • استفاده از نمونه‌های کاغذی برای بازخورد طراحی در مراحل اولیه
  • پیاده‌سازی الگوهای طراحی سازگار در سراسر برنامه
  • اولویت‌بندی دسترسی برای کاربران با ناتوانی‌ها
  • تحلیل منظم داده‌های رفتار کاربر برای اطلاع‌رسانی تصمیمات طراحی
  • تلاش برای تعادل بین عملکرد و سادگی

5. تصمیمات استراتژیک کسب‌وکار مسیرهای توسعه‌ی نرم‌افزار را شکل می‌دهند

اگر یک عملکرد اصلی کسب‌وکار است—خودتان انجام دهید، به هر قیمتی.

شایستگی‌های اصلی باید داخلی باشند. شرکت‌ها باید بر توسعه و نگهداری عملکردهای اصلی کسب‌وکار خود به صورت داخلی تمرکز کنند، به جای برون‌سپاری آن‌ها. این رویکرد اطمینان می‌دهد که کنترل بر جنبه‌های حیاتی کسب‌وکار حفظ می‌شود و نوآوری تقویت می‌شود.

شراکت‌های استراتژیک می‌توانند مفید باشند. برای عملکردهای غیر اصلی، شراکت‌های استراتژیک یا برون‌سپاری می‌توانند راه‌های مؤثری برای دسترسی به تخصص‌های خاص یا کاهش هزینه‌ها باشند.

ملاحظات کلیدی برای تصمیمات استراتژیک:

  • شناسایی و حفاظت از عملکردهای اصلی کسب‌وکار
  • ارزیابی شراکت‌ها یا خریدهای بالقوه برای فناوری‌های مکمل
  • در نظر گرفتن پیامدهای بلندمدت انتخاب‌های فناوری
  • تعادل بین نیاز به نوآوری و نگهداری محصولات موجود
  • ارزیابی منظم چشم‌انداز رقابتی و تنظیم استراتژی‌ها بر این اساس
  • سرمایه‌گذاری در تحقیق و توسعه برای پیشی گرفتن از روندهای بازار

6. ارتباط مؤثر در تیم‌های توسعه‌ی نرم‌افزار ضروری است

برنامه‌نویسان در قلب خود معمار هستند و اولین چیزی که می‌خواهند وقتی به یک سایت می‌رسند انجام دهند این است که مکان را صاف کنند و چیزی بزرگ بسازند.

ارتباط واضح حیاتی است. ارتباط مؤثر درون تیم‌های توسعه و با ذینفعان برای موفقیت پروژه ضروری است. این شامل بیان واضح اهداف پروژه، نیازهای فنی و چالش‌های بالقوه است.

مدیریت انتظارات مهم است. به‌روزرسانی منظم ذینفعان در مورد پیشرفت پروژه و مسائل بالقوه به مدیریت انتظارات و ایجاد اعتماد کمک می‌کند. این امر به‌ویژه زمانی که با مفاهیم فنی پیچیده‌ای که ذینفعان غیر فنی ممکن است به‌طور کامل درک نکنند، سروکار داریم، مهم است.

استراتژی‌های ارتباط مؤثر:

  • جلسات تیمی منظم و به‌روزرسانی‌های وضعیت
  • مستندسازی واضح تصمیمات و دلایل
  • استفاده از کمک‌های بصری (نمودارها، ماکاپ‌ها) برای توضیح مفاهیم پیچیده
  • تشویق به گفتگوی باز و بازخورد سازنده
  • ایجاد کانال‌های واضح برای گزارش مسائل یا نگرانی‌ها
  • تطبیق سبک ارتباط با مخاطب (فنی در مقابل غیر فنی)

7. یادگیری و تطبیق مداوم در صنعت فناوری به سرعت در حال تحول کلیدی است

هیچ چیز به سادگی که به نظر می‌رسد نیست.

پذیرش یادگیری مداوم. صنعت فناوری به سرعت تکامل می‌یابد، و یادگیری و تطبیق مداوم برای باقی ماندن در رقابت ضروری است. توسعه‌دهندگان و مدیران باید به‌طور فعال به دنبال دانش و مهارت‌های جدید باشند.

آمادگی برای پیچیدگی. حتی وظایف به ظاهر ساده می‌توانند پیچیدگی‌های پنهانی داشته باشند. نزدیک شدن به مشکلات با ذهنیتی که چالش‌ها را پیش‌بینی می‌کند می‌تواند به راه‌حل‌های قوی‌تری منجر شود.

استراتژی‌های یادگیری و تطبیق مداوم:

  • تشویق به آزمایش با فناوری‌های جدید
  • تخصیص زمان برای یادگیری و توسعه‌ی حرفه‌ای
  • پرورش فرهنگی که به اشتراک‌گذاری دانش ارزش می‌دهد
  • آگاهی از روندهای صنعت و فناوری‌های نوظهور
  • ارزیابی و به‌روزرسانی منظم فرآیندها و ابزارهای توسعه
  • پذیرش شکست به عنوان یک فرصت یادگیری

8. درک پویایی‌های بازار برای موفقیت محصول نرم‌افزاری حیاتی است

ایده‌ی تبلیغات این است که بدون گرفتار شدن دروغ بگویید.

آگاهی از بازار حیاتی است. درک پویایی‌های بازار، از جمله نیازهای مشتری، استراتژی‌های رقبا و روندهای صنعت، برای موفقیت محصول نرم‌افزاری ضروری است. این دانش باید توسعه‌ی محصول و استراتژی‌های بازاریابی را اطلاع‌رسانی کند.

پیشنهاد ارزش صادقانه کلیدی است. در حالی که نقل قول به‌طور طنزآمیز به تبلیغات اشاره دارد، توسعه‌ی یک پیشنهاد ارزش صادقانه و واضح برای محصول شما حیاتی است. این به ایجاد اعتماد با مشتریان کمک می‌کند و یک مزیت رقابتی پایدار ایجاد می‌کند.

جنبه‌های کلیدی درک بازار:

  • بازخورد منظم مشتری و تحقیقات بازار
  • تحلیل رقابتی برای شناسایی شکاف‌ها و فرصت‌ها
  • پیگیری روندهای صنعت و پیشرفت‌های فناوری
  • تطبیق استراتژی‌های محصول بر اساس بینش‌های بازار
  • توسعه‌ی یک پیشنهاد فروش منحصر به فرد که با مشتریان هدف همخوانی دارد
  • تعادل بین تقاضاهای کوتاه‌مدت بازار و چشم‌انداز بلندمدت محصول

9. مدل‌های نرم‌افزار منبع باز و اختصاصی هر کدام مزایای خاص خود را دارند

بیشتر شرکت‌هایی که پول زیادی برای توسعه‌ی نرم‌افزار منبع باز خرج می‌کنند، این کار را انجام می‌دهند زیرا این یک استراتژی کسب‌وکار خوب برای آن‌هاست، نه به این دلیل که ناگهان به سرمایه‌داری اعتقاد خود را از دست داده‌اند و عاشق آزادی به معنای گفتار شده‌اند.

منبع باز ارزش استراتژیک دارد. بسیاری از شرکت‌ها به عنوان بخشی از استراتژی کسب‌وکار خود در نرم‌افزار منبع باز سرمایه‌گذاری می‌کنند، نه فقط به دلایل نوع‌دوستانه. این رویکرد می‌تواند به ایجاد اکوسیستم‌ها، افزایش پذیرش و کاهش هزینه‌های توسعه کمک کند.

نرم‌افزار اختصاصی اهمیت خود را حفظ می‌کند. با وجود رشد منبع باز، نرم‌افزار اختصاصی در بسیاری از بخش‌ها، به‌ویژه برای برنامه‌های تخصصی یا حیاتی، همچنان حیاتی است.

ملاحظات برای نرم‌افزار منبع باز در مقابل اختصاصی:

  • ارزیابی مزایای استراتژیک مشارکت‌های منبع باز
  • در نظر گرفتن پتانسیل نوآوری و رفع باگ‌های جامعه‌محور
  • ارزیابی تأثیر بر مدل کسب‌وکار و جریان‌های درآمدی
  • تعادل بین نیاز به کنترل و مزایای همکاری باز
  • درک پیامدهای مجوز استفاده از اجزای منبع باز
  • در نظر گرفتن پایداری بلندمدت هر دو رویکرد در بازار خود

آخرین به‌روزرسانی::

نقد و بررسی

4.12 از 5
میانگین از 3k+ امتیازات از Goodreads و Amazon.

کتاب جوئل درباره‌ی نرم‌افزار مجموعه‌ای از مقالات در زمینه‌ی توسعه‌ی نرم‌افزار، مدیریت پروژه و دیدگاه‌های صنعتی است. خوانندگان از توصیه‌های عمل‌گرایانه، طنز و تجربیات واقعی اسپولسکی قدردانی می‌کنند. این کتاب موضوعاتی مانند پیگیری باگ‌ها، مشخصات، استخدام و بهره‌وری را پوشش می‌دهد. اگرچه برخی از محتواها قدیمی شده‌اند، اما بسیاری از اصول همچنان مرتبط هستند. منتقدان به تعصب نسبت به مایکروسافت و پیش‌بینی‌های قدیمی اشاره می‌کنند. بیشتر منتقدان ارزش دیدگاه‌های اسپولسکی در مورد شیوه‌های مهندسی نرم‌افزار را یافتند، حتی اگر با برخی نکات موافق نبودند. این کتاب به دلیل ترکیب دانش فنی و خرد مدیریتی توصیه می‌شود.

Joel On Software Series Series

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

جوئل اسپولسکی یک توسعه‌دهنده نرم‌افزار، نویسنده و کارآفرین است. او به عنوان مدیر برنامه در تیم اکسل در مایکروسافت کار می‌کرد قبل از اینکه در سال 2000 شرکت Fog Creek Software را تأسیس کند. اسپولسکی به خاطر وبلاگش "Joel on Software" شناخته می‌شود که مبنای این کتاب را تشکیل داده است. او در سال 2008 سایت محبوب پرسش و پاسخ برای برنامه‌نویسان به نام Stack Overflow را هم‌تأسیس کرد. سبک نوشتاری اسپولسکی ترکیبی از تخصص فنی با طنز و بینش‌های عملی است. او در شکل‌دهی به بحث‌ها پیرامون روش‌های توسعه نرم‌افزار، مدیریت پروژه و روندهای صنعت فناوری تأثیرگذار بوده است. تجربه او از محیط‌های بزرگ شرکتی تا فرهنگ استارتاپی گسترده است و به او دیدگاه منحصربه‌فردی در دنیای نرم‌افزار می‌دهد.

0:00
-0:00
1x
Dan
Andrew
Michelle
Lauren
Select Speed
1.0×
+
200 words per minute
Create a free account to unlock:
Bookmarks – save your favorite books
History – revisit books later
Ratings – rate books & see your ratings
Unlock unlimited listening
Your first week's on us!
Today: Get Instant Access
Listen to full summaries of 73,530 books. That's 12,000+ hours of audio!
Day 4: Trial Reminder
We'll send you a notification that your trial is ending soon.
Day 7: Your subscription begins
You'll be charged on Dec 4,
cancel anytime before.
Compare Features Free Pro
Read full text summaries
Summaries are free to read for everyone
Listen to summaries
12,000+ hours of audio
Unlimited Bookmarks
Free users are limited to 10
Unlimited History
Free users are limited to 10
What our users say
30,000+ readers
“...I can 10x the number of books I can read...”
“...exceptionally accurate, engaging, and beautifully presented...”
“...better than any amazon review when I'm making a book-buying decision...”
Save 62%
Yearly
$119.88 $44.99/yr
$3.75/mo
Monthly
$9.99/mo
Try Free & Unlock
7 days free, then $44.99/year. Cancel anytime.
Settings
Appearance