برنامه نویس اندرویدی که به همه میگه خودتو پیدا کن واسه بقیه چیزها گوگل هست ;)
خلاصه کتاب کدنویس تمیز (The Clean Coder)
سلام سلام ✋
من هماشفیعی ام، یک جوان عاشق برنامه نویسی که توسعه دهنده اندروید هستم... ?
آشنایی من با زبانهای برنامه نویسی از دوران دبیرستان شروع شد که در کتاب درسی مبانی کامپیوتر ویژوال بیسیک تدریس میشد و همونجا بود که من به الگوریتم نویسی و دنیای برنامه نویسی علاقه مند شدم و بعد از اون در دانشگاه به طور کاملا اتفاقی رشته مهندسی کامپیوتر گرایش سختافزار دانشگاه فردوسی مشهد قبول شدم از همون سال های ورودم به دانشگاه همزمان با درس خوندن، کار کردن رو هم شروع کردم و اینجوری شد که خیلی زود وارد بازار کار شدم اما از اونجایی که خیلی کمال گرام و هرکاری رو که شروع میکنم باید به بهترین شکل ممکن انجام بدم، ورودم به بازار کار باعث شد بیشتر برای درس خوندن تلاش کنم و اینجوری شد که تونستم بین هم ورودی های خودم معدل بالایی داشته باشم و ارشدم بدون کنکور وارد رشته مهندسی کامپیوتر گرایش نرمافزار دانشگاه فردوسی مشهد بشم، در دانشگاه به واسطه کانکشن های خوبی که ایجاد میشد نه تنها باعث شد پروژه های خوبی بگیرم بلکه از اون مهمتر باعث شد با کلی جوان بااستعداد و باانگیزه آشنا بشم که در حال حاضر برنامه نویسای حرفهای چه در ایران و چه در خارج از کشور هستند.
خب دیگه بیوگرافی بسه و بریم سراغ دلیل ایجاد این پست.
مدتی بود که کتاب کدنویس تمیز روی میز مدیر فنیمون توجهامو جلب میکرد یک روز بالاخره بهش گفتم میشه من این کتاب یک هفتهای قرض بگیرم اونم قبول کرد و یک پیشنهاد جالبی داد و گفت وقتی که تموم کردی اگه تمایل داری میتونی یک جلسه بذاریم و راجع بهش صحبت کنیم. در واقع اینجوریه که در شرکتی که مشغول به کارم هر چند وقت یک بار یکی از اعضای تیم فنی یک جلسهای در مورد مباحث جدید مرتبط با اندروید که اومده و لازمه به پروژه اضافه بشه یا بدهی فنیهایی که خوبه انجام بشه میذاره اما این دفعه این فرصت به من داده شد که جلسه در مورد رشد شخصی خودمون بذاریم.
خلاصه قرار بر این شد که بعد از مطالعه کتاب برای به اشتراکگذاری دانش و درک مطالب کتاب، خلاصهای از کتاب به بحث و تعامل گذاشته بشه و بعد به این نتیجه رسیدم که چرا خلاصه نویسی محدود به اعضای تیم بشه چرا اونو منتشر نکنم تا بقیه دوستان علاقه مند هم بتونن استفاده کنن؟
خب دیگه خیلی حرفهای پراکنده زدم بریم سراغ خلاصه کتاب.
این کتاب درباره حرفهای بودن در زمینه نرمافزار است و شامل تعداد زیادی توصیه عملی در تلاش به پاسخ گویی به سوالاتی از قبیل موارد زیر است:
· یک حرفهای (در زمینهی) نرمافزار کیست؟
· یک حرفهای چگونه رفتار میکند؟
· یک حرفهای چگونه با مناقشهها، برنامههای تنگاتنگ و مدیران غیرمنطقی کنار میآید؟
· یک حرفهای چه زمانی و چگونه باید "نه" بگوید؟
· یک حرفهای چگونه با فشارها کنار میآید؟
من فرض میکنم شما این کتاب را انتخاب کردهاید، چون یک برنامهنویس کامپیوتر هستید و با مفهوم حرفهای بودن آشنایید. در واقع باید آشنا باشید چون حرفهای بودن، چیزی است که حرفه ما شدیدا به آن نیاز دارد.
پس میخواهید یک توسعهدهنده نرمافزار حرفهای باشید. بله؟ میخواهید سرتان را بالا گرفته و به دنیا اعلان کنید: "من یک حرفهای هستم!". میخواهید که مردم با احترام به شما نگاه کنند و با شما متفاوت رفتار کنند. میخواهید مادران به شما اشاره کنند و به فرزندان خود بگویند که مثل شما باشند. تمام اینها را میخواهید. درست است؟
مراقب چیزی که میخواهید، باشید!
حرفهای بودن، عبارتی مسئولیت آور است. بدیهی است که حرفهای بودن یک نشان افتخار و غرور است اما نشانگر مسئولیت و پاسخگویی نیز هست. شما نمیتوانید غرور و افتخار چیزی را داشته باشید که پاسخگوی آن نیستید.
پذیرش مسئولیت
حرفهای بودن همان مسئولیت پذیری است. غیرحرفهای بودن بسیار سادهتر است. غیر حرفهایها لازم نیست مسئولیت کاری که میکنند را بپذیرند، بلکه این مسئولیت را به کارفرمایشان محول میکنند. اگر یک غیر حرفهای خطایی کند، کارفرمایش آن را جمع میکند اما زمانی که یک حرفه ای خطایی کند، خودش باید بهم ریختگی ناشی از آن را جمع کند.
چگونه مسئولیت بپذیریم؟
اول اینکه آسیب نزنید!
واضح است که ما میخواهیم نرمافزارمان کار کند. مشتریان و کارفرمایان به ما پول میدهند تا نرمافزاری بسازیم که همانطور که آنها میخواهند، کار کند. زمانی که باگها را میسازیم عملکرد نرمافزار ما آسیب میبیند. در نتیجه برای حرفهای بودن، باید باگها را نسازیم.
قطعا نوشتن برنامه بدون باگ عملا غیرممکن است اما باید مسئولیت آن را بپذیریم و پاسخگو باشیم... پس اولین چیزی که باید تمرین کنید عذرخواهی کردن است، عذرخواهی کردن لازم است اما کافی نیست. شما نباید خطاهای یکسانی را بارها و بارها مرتکب شوید. اما بایستی نرخ خطای خود را تا حد امکان به صفر نزدیک کنید.
بخش کنترل کیفیت یا QA نباید چیزی پیدا کند
زمانی که نرمافزار خود را منتشر میکنید، باید انتظار داشته باشید که QA هیچ مشکلی پیدا نکند. این کار شدیدا غیرحرفهای است که عمدا کدی را ارسال کنید که میدانید از نظر QA معیوب است.
کدام کد معیوب است؟ هر کدی که درباره آن مطمئن نیستید!
هربار که QA یا بدتر از آن، یک کاربر، مشکلی پیدا کند، باید شگفت زده و اندوهگین شوید و برای جلوگیری از وقوع مجدد آن، مصمم شوید.
باید بدانید که کار میکند
چطور بفهمید که کد شما کار میکند؟ ساده است، آن را تست کنید. مجددا تست کنید. تمام زیروبر آن را تست کنید. آن را به هفت شیوه مختلف تست کنید!
تست کردن زمانبر است-> تست های خود را خودکار انجام دهید یعنی تستهای واحد بنویسید.
به ساختار آسیب نزن
هر بار که یک ماژول را بررسی نهایی میکنید باید تمیزتر از بررسی اولیه باشد.
چرا بیشتر توسعه دهندگان از اعمال مداوم تغییرات به کد خود هراس دارند؟ آنها میترسند کد را بشکنند... چرا؟ چون تست ندارند.
توسعه دهندگان حرفهای به قدری از کد و تستهای خود مطمئن هستند که گاه به گاه دیوانهوار تغییراتی فرصت طلبانه و تصادفی را در کد ایجاد میکنند.
به طور خلاصه آنها طوری با نرمافزار رفتار میکنند که یک مجسمهساز با خاک رس رفتار میکند به طور مداوم به آن شکل و قالب میدهند.
اخلاق کاری
حرفه شما، مسئولیت شما است. این وظیفه کارفرمای شما نیست که به شما آموزش دهد یا شما را به کنفرانسها بفرستد یا برای شما کتاب بخرد. این چیزها مسئولیت خود شماست. وای به حال توسعه دهندهای که حرفه خود را به کارفرمایش سپرده است.
برخی از کارفرمایان مایل هستند برای شما کتاب بخرند و شما را به کنفرانسها وکلاسهای آموزشی بفرستند. بسیار خب آنها به شما لطف میکنند، اما هرگز در دام این تفکر نیفتید که این مسئولیت کارفرمای شماست.
تقریبا سه ساعت در روز را صرف یادگیری کنید.
اینکه کار را با خودتان ببرید خونه مورد بحث نیست اما اینکه برای آموزش خودتان وقت بگذارید حرفهایست.
رشته خود را بشناسید
آیا میدانید چارت nassi schneiderman چیست؟ اگر جواب منفی است چرا نمیدانید؟ تفاوت ماشین حالت میلی و مور را میدانید؟ آنالیز تبدیل به چه معناست؟ معنی اصلاح داده ولگرد (tramp data) چیست؟ جدول پارناس چیست؟ حرفهایها بخش قابل ملاحظهای از اینها را میدانند!!
یادگیری مداوم
برنامهنویسانی که قادر به یادگیری روشها و تکنیکهای جدید نیستند، از بقیه عقب مانده و کنار گذاشته خواهند شد.
تمرین
حرفهایها تمرین میکنند. انجام دادن کارهای روزانه تمرین محسوب نمیشه. انجام کار روزانه شما عملکرد شماست نه تمرین!
برای تمرین میتوان الگوریتمهای ساده رو نوشت مثل نوشتن عوامل اول یک عدد صحیح
همکاری
حرفهایها در پروژههای اپن سورس همکاری میکنند.
مربیگری
بهترین راه برای یادگرفتن تدریس کردن است.
حوزه خود را بشناسید
حوزه خود را بشناسید و در آن حوزه یک یا دو کتاب بخوانید. به عنوان مثال اگر در حال نوشتن سیستم حسابداری هستید باید رشته حسابداری را بشناسید.
با کارفرما یا مشتری خود، شناخته شوید
مشکلات کارفرمای شما، مشکلات شما است. باید درک کنید که آن مشکلات چه هستند. در هنگام توسعه باید با کفشهای کارفرما راه برویم که مطئمن شویم ویژگیهایی که در حال توسعه آن هستیم واقعا نیازهای کارفرما را پاسخ خواهند داد.
تواضع
یک حرفهای دیگران را به خاطر یک اشتباه تحقیر نخواهد کرد زیرا ممکن است نفر بعدی که اشتباه میکند خودش باشد.
نه گفتن
حرفهایها شجاعت نه گفتن به مدیران خود را دارند. بردگان اجازه ندارند نه بگویند. کارگران ممکن است برای نه گفتن مردد باشند اما از حرفهایها انتظار میرود نه بگویند.
اگر شما به خوبی میدانید که آماده کردن صفحه ورودی تا فردا غیرممکن است اما بگویید "باشه سعی خودم را میکنم" کار خود را انجام ندادهاید. تنها راه، برای انجام دادن کارتان در آن لحظه، این است که بگویید "نه این غیرممکن است".
تعهد داشتن
زبان تعهد یعنی: گفتن، قصد داشتن، انجام دادن
سه بخش برای ساختن یک تعهد وجود دارد:
۱. شما میگویید که آن را انجام خواهید داد.
۲. قصد آن را پیدا میکنید.
۳. واقعا آن را انجام میدهید.
افراد بسیار کمی هستند که زمانی که چیزی میگویند، قصد آن را دارند و سپس آن را واقعا انجام میدهند.
برخی دیگر هستند که چیزهایی میگویند و قصد آن را دارند اما هرگز آن را انجام نمیدهند.
افراد بسیار بیشتری وجود دارند که وعده میدهند و حتی قصدی برای انجام آن ندارند.
تشخیص عدم تعهد
چند نمونه از کلمات و عباراتی که نشاندهنده دلیل بر عدم تعهد است:
۱.لازم است/ باید:
لازم است ما این را انجام دهیم
کسی باید این اتفاق را رقم بزند
۲ . امید و آرزو (کاش):
امیدوارم تا فردا این را انجام دهم.
کاش زمانی برای آن داشتم.
۳. بیایید:
بیایید گاهی اوقات قرار بگذاریم.
بیایید این کار را تمام کنیم.
تعهد چه شکلی است؟
جملاتی مثل "من اینکار را تا سه شنبه تمام خواهم کرد".
کدنویسی
برنامهنویسی یک فعالیت فکری چالش برانگیز و طاقت فرساست. این فعالیت، نیاز به سطحی از تمرکز و توجه دارد.
ویژگیهای کدی که مینویسیم.
۱. اول اینکه کد شما باید کار کند. شما باید درک کنید که چه مشکلی را دارید حل میکنید.
۲. کد شما باید مساله تعریف شده توسط مشتری را حل کند.
۳. کد شما باید با سیستم فعلی متناسب باشد.
۴. کد شما باید توسط دیگران برنامهنویسان قابل خواندن باشد.
کد ساعت ۳ صبح
فکر میکردم که دارم فداکاری میکنم و کار کردن در ساعت ۳ صبح همان کاری است که حرفهایها انجام میدهند. در حالی که آن کد در آینده به مشکلی بزرگتر تبدیل شد.
کد اضطراب
بعد از یک دعوای حسابی با همسر بعد از آن سعی کنید برنامه ننویسید؟ آن زمان برای برنامهنویسی مناسب نیست. هر برنامهای که تولید کنید بیاستفاده خواهد بود. بنابراین اول باید نگرانیتان را حل کنید.
موسیقی
موسیقی ممکن است به شما برای نوشتن کد کمک کند اما من بعید میدانم.
مسدود شدن ذهن نویسنده
گاهی اوقات کد نمیآید. در محل کار نشستهاید و هیچ اتفاقی نمیافتد.
راه حل: دو نفره کار کنید.
اضافه کاری
اضافه کاری میتواند مفید باشد و گاهی اوقات لازم است. اما این کار بسیار خطرناک است.
اگر اضافه کاری بیش از دو یا سه هفته طول بکشد قطعا با شکست مواجه خواهد شد. در نتیجه نباید با اضافه کاری موافقت کنید مگر اینکه شخصا بتوانید از عهده آن برآیید.
تحویل غلط
بدترین مورد این است که وقتی میدانید کاری را انجام ندادهاید بگویید آن را انجام دادهاید.
کمک کردن به دیگران
مسئولیت برنامهنویسان است که برای کمک به یکدیگر در دسترس باشند. این خارج از اخلاق حرفهای است که خود را در یک دفتر یا اتاق از دیگران مجزا کنید و پرسشهای دیگران را رد نمایید.
مشارکت در پروژههای متن باز
یک کاری که وکلا و پزشکان انجام میدهند انجام کارهای عامالمنفعه است. حرفهایها هم در پروژههای متن باز مشارکت میکنند.
جلسات
نپذیرفتن
شما مجبور نیستید در هر جلسهای که دعوت میشوید شرکت کنید. در واقع بیش از حد رفتن به جلسات، غیر حرفهای است. شما مسئول مدیریت زمان خودتان هستید.
منبع: کتاب کدنویس تمیز (The Clean Coder) اثر رابرت سی مارتین (“عمو باب”)
(راستی اگه دوست داشتی میتونی منو توی لینکدین هم دنبال کنی)
مطلبی دیگر از این انتشارات
نظریاتی در باب دیتابیس ها
مطلبی دیگر از این انتشارات
علت های شکست پروژه های نرم افزاری ERP در سازمان ها
مطلبی دیگر از این انتشارات
درباره خطای CORS