الگوهای طراحی حرفه ای - TypeScript

الگوهای طراحی حرفه ای - TypeScript

حل مساله به روش کدنویسی پیشرفته و تمیز، برای مسائل واقعی دنیای نرم افزار
شروع دوره بلافاصله پس از ثبت نام
زمان یادگیری دوره ۳ ماه (۱۰ساعت در هفته)
کیوان علی محمدی
مدرس: کیوان علی محمدی مدیر عامل

آشنایی با دوره الگوهای طراحی حرفه ای - TypeScript

اولین تجربه من در الگوهای طراحی

اولین تسک فنی (یک مسئله) من در یک شرکت بزرگ که به عنوان برنامه نویس Backend در اون مشغول به کار شده بودم، مسئله ای بود که در نگاه اول بسیار عجیب و غریب به نظر می‌رسید و یک راه حل عجیب و غریب هم براش در نظر گرفته بودن.

داستان از این قرار بود که در نرم افزار شرکت از یک پکیج برای ثبت نام و لاگین کاربر با استفاده از یاهو و گوگل استفاده شده بود و مشکلی که این پکیج داشت این بود که اگر کاربری اکانت یاهو داشت آدرس جی میل خودش رو به عنوان آدرس اصلی یا Primary ثبت میکرد، همون آدرس به برگشت داده میشد و عملا ما کاربری داشتیم که با یاهو ثبت نام کرده اما آدرس ایمیلش به جای @yahoo.com با @gmail.com تموم میشد.

تیم محصول تاکید داشتن کاربر یاهو حتما باید آدرس ایمیل یاهو ازشون گرفته بشه و تیم فنی برای حل این مساله شروع کرده بود به بررسی کدهای اون پکیج. اما راه حل چی بود؟ تیم فنی تصمیم گرفته بود اون کلاسی که مسئول دریافت آدرس ایمیل‌های کاربران هست رو داخل خود پکیج تغییربده و عملا پکیج رو مجبور کنه که برای کاربران یاهو آدرس یاهو رو برگردونه.

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

راه حل دومی که ارائه شده بود این شکلی بود که اون کلاس به داخل کدهای برنامه کپی شده بود و با استفاده از یک bash script زمانی که پکیج‌ها به روز رسانی میشدن این کلاس به کلاس اصلی پکیج جایگزین میشد. اما مشکل این راه حل دوم چی بود؟

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

من بعد از بررسی مساله و به خاطر مطالعات زیادی که روی الگوهای طراحی داشتم راه حل استفاده از الگوی طراحی Adapter رو مطرح کردم.

در این روش ما با ایجاد یک کلاس تازه در کدهای برنامه که کلاس مورد نظر داخل پکیج رو توسعه میده و public api اون در بخش دریافت آدرس ایمیل رو بازنویسی میکنه عملا تونستم مشکل رو حل کنم.

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

الگوهای طراحی چیه؟

بیاید با این سوال شروع کنیم؟ آیا برنامه نویسی چیزی جز حل مساله هست؟ قطعا نه .الگوریتم،ساختمان داده،معماری و . همه و همه اینجا هستن تا ما به عنوان یک برنامه نویس یک مسئله رو حل کنیم. حل مساله اولین و مهمترین مهارت یک برنامه نویس محسوب میشه. در برنامه نویسی شما یه ابزار به اسم زبان برنامه نویسی داری که باید با استفاده از امکاناتی که در اختیار شما قرار میده مسئله رو حل کنید.

خب میرسیم به این سوال که آیا برای یک مسئله راه حل‌های مختلفی می‌تواند وجود داشته باشه؟ قطعا بله. قطعا برای هر مسئله ای هم راه حل‌های ساده وجود دارد و هم راه حل‌های پیچیده و این مورد در دنیای برنامه نویسی هم صدق میکنه.

سوال بعدی که می‌توانیم مطرح کنیم این است که بهترین روش حل مسئله کدام است؟ بدون شک ساده‌ترین روش حل مسئله بهترین روش حل مسئله هست و ما همیشه باید در نظر داشته باشیم مهم‌ترین چیز در توسعه نرم افزار قابلیت نگهداری نرم افزار یا Maintainability هست. پس باید بدونیم که باید بهترین روش حل مساله اونی هست که ساده‌ترین روش باشه و به قابلیت نگهداری نرم افزار کمک کنه.

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

الگوهای طراحی به عنوان Best Practice‌های حل مساله در دنیای کدنویسی شناخته میشن و روش هایی هستن که در نهایت کمک میکنن ما یک نرم افزار با قابلیت نگهداری بالا داشته باشیم. الگوهای طراحی، اختراع (invent) یا ساخته نشدن بلکه به مرور زمان توسط برنامه نویس‌های مختلف کشف (discover) شدن و به صورت یک سری قاعده abstract معرفی شدن که در مسائل مختلفی میشه ازشون استفاده کرد.

شاید براتون سوال باشه چرا بهشون الگوی طراحی گفته میشه؟

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

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

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

چرا الگوهای طراحی مهمه؟

تا حالا به این مورد فکر کردین چرا خیلیا نمی‌تونن از شی گرایی درست استفاده کنن؟

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

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

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

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

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

چطوری باید الگوهای طراحی رو یاد بگیریم؟

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

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

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

روش من برای انتقال این تجربه

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

چرا باید چند مثال و اونم مثال‌های واقعی برای هر الگو رو بررسی کنیم؟

خب واقعیت ماجرا اینه که مثال هایی که در اکثر جاها استفاده میشه،بر اساس مسائل صرفا تئوری و کار با موجودیت هایی مثل Car,Book,Animal,Human پیاده سازی شده و به ندرت در نرم افزارهای دنیای واقعی استفاده میشه و به خاطر همین موضوع باید مثال هایی از دنیای واقعی مطرح بشه.

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

آیا این دوره به درد من میخوره؟

  •  اگر تازه یک زبان برنامه نویسی شی گرا مثل PHP,Java,TypeScript یاد گرفتی و میخوای یاد بگیری در مراحل پیشرفته‌تر چطوری باید مسائل رو حل کنی، قطعا این دوره بهت کمک میکنه خیلی راحت‌تر به هدفت برسی.
  •  بدون شک یکی از مباحث اصلی مصاحبه‌های استخدامی و سوالات اون برای یک برنامه نویس، بحث الگوهای طراحی محسوب میشه، پس اگر مصاحبه استخدامی و سوالات فنی اون برات یک دغدغه هست قطعا این دوره میتونه بهت کمک کنه.
  •  افزایش مهارت فنی،یکی از راه هایی هست که برنامه نویس می‌تونه بر اساس اون درخواست افزایش حقوق بده، خب اگر تازه مثلا 6 ماه بیشتر هست که مشغول به کار شدی و تمایل داری حقوقت افزایش پیدا کنه میتونی بر اساس مهارت در الگوهای طراحی که منجر به کدنویسی بهتر میشه درخواست افزایش حقوق بدی.
  •  اگر تمایل داری وارد پروژه‌های سازمانی بشی و میخوای درک بهتری از شی گرایی داشته باشی،قطعا این دوره کمکت میکنه از یک زاویه دیگه به شی گرایی نگاه کنی.

دوره به چه روشی برگزار میشه؟

در ابتدای دوره با مفاهیم SOLID شروع میکنیم و به صورت کاربردی یاد میگیری که این مفاهیم دقیقا چی هستن، چرا باید ازشون استفاده کرد و کجا باید اونهارو رعایت کنی و به کار بگیری.

تعداد ۱۸ الگوی طراحی که کاربردهای بسیار زیادی دارن و در کتاب‌های مرجع تعریف شده است که این تعداد در ۳ دسته بندی با نام‌های Creational,Structural,Behavioral قرار گرفته است. ما بر اساس این دسته بندی‌ها برای هر الگوی طراحی تعدادی ویدیو شامل تعریف تئوری الگوی طراحی به همراه تعریف و راه حل چند مسئله کاربردی (بر اساس دنیای واقعی نرم افزار) بر اساس همان الگو در اختیارت قرار میدیم.

پیش نیازهای شرکت در این دوره چیه؟

برای اینکه بتونید در دوره شرکت کنید و نتیجه خوبی بگیرید ازش، حتما باید با یک زبان شی گرایی کار کرده باشید و مفاهیم شی گرایی مقدماتی رو بلد باشید.

زمان و روزهای برگزاری دوره چه طوری هست؟

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

این روش جدید کمک میکنه زمان خودت تعیین کنی ویدیوها رو کی ببینی و البته یادت باشه اگر واقعا میخوای از دوره نتیجه بگیری حتما حتما در طول هفته باید ویدیوها رو ببینی و تمرین کنی.

این دوره واقعا چقدر تاثیر داره؟

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

این دوره فقط و فقط به شما کمک میکنه مسیر درست رو پیدا کنید و به سمتش برید. این دوره می‌تونه مدت زمان یادگیری رو برای شما کاهش بده. افراد زیادی هستن که بدون یک دوره خاص هم می‌تونن به هدفشون برسن اما ممکنه زمان بیشتری نیاز داشته باشن مخصوصا اگر پیش زمینه ای در اون بحث نداشته باشن.

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

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

آموزش بر اساس چه پلتفرم و زبان برنامه نویسی خواهد بود؟

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

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

تفاوت اصلی این دوره با دوره‌های مشابه چیه؟

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

توی این دوره سعی بر این بوده که تمام مثال‌ها بر اساس مشکلات و مسائل واقعی دنیای نرم افزار مطرح بشه تا هم به راحتی الگوهای طراحی رو درک کنید و هم اینکه توانایی حل مساله با استفاده از شی گرایی شما قوی بشه.

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

آیا این دوره با این قیمت واقعا ارزشش رو داره؟

الان می‌تونیم بگیم یک توسعه دهنده Junior یه حقوقی بین رنج ۴ الی ۶ میلیون تومن درآمد داره و یه توسعه دهنده Mid-Level بین ۸ الی ۱۲ تومن و در نهایت یک توسعه دهنده Senior از ۱۲ الی ۲۵ تومن حقوق دریافت می‌کنه.

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

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

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

آنچه شما یاد خواهید گرفت

  • آماده سازی محیط و پیش نیاز ها

  • هفته اول - اصول SOLID در توسعه نرم افزار

    اصول SOLID از موارد مهم در توسعه نرم افزار هستند که در هفته اول دوره این 5 اصل مهم رو به صورت کاملا کاربردی بررسی می‌کنیم.بررسی اصل Single Responsibility و پیاده سازی آن به صورت کاربردیبررسی اصل Open-Closed و پیاده سازی کاربردی آن + دیدگاه رابرت مارتین و برتراند میربررسی اصل Liskov Substitution و پیاده سازی کاربردی آنبررسی اصل Interface Segregation و پیاده سازی کاربردی آنبررسی اصل Dependency Inversion و پیاده سازی کاربردی آن

  • هفته دوم - الگوی طراحی Factory Method و Abstract Factory

    در هفته دوم ۲ الگوی مهم در دسته بندی Creational رو بررسی می‌کنیم. الگوی Factory Method و الگوی Abstract Factory که هر کدوم در بخش ایجاد اشيا می‌تونن به بهینه سازی کدهای ما کمک کنند.الگوی طراحی Factory Method یکی از الگوهای اصلی برای ساختن اشیاء محسوب میشه که کاربردهای زیادی داره. این الگو زمانی استفاده میشه که بخوایم یک یا چند عملیات خاص رو انجام بدیم و اون عملیات‌ها توسط کلاس‌های مختلفی قابل انجام هست. ما می‌تونیم بدون این الگو اون کلاس‌ها رو نمونه سازی کنیم و ازشون استفاده کنیم اما دردسر ما تازه شروع میشه چون باید برای هر کلاس جدید کدهای جدید رو به کلاس اصلی اضافه کنیم. مثلا در درگاه‌های پرداخت وقتی قرار پرداخت آنلاین انجام بشه به جای نوشتن کدهای شرطی مختلف می‌تونیم یک متد داشته باشیم که نمونه ای از کلاس‌های مختص پرداخت آنلاین رو برای ما بسازه و اون شی رو در اختیار کلاس اصلی قرار بده. در این حالت دیگه نیازی نیست برای تغییر اون کلاس بیایم و کلاس اصلی و شرط‌ها رو تغییر بدیم.الگوی Abstract Factory هم در مورد اشیاء و ساختن اونها استفاده میشه، این الگو برای ساختن مجموعه از اشیاء مرتبط با هم استفاده میشه. مثلا میخوایم یک صفحه ساز ایجاد کنیم که برای header و footer و body اون فرمت‌های مختلفی رو پشتیبانی کنیم. در این حالت هر بخش از این صفحه سازی باید استاندارد خودش رو داشته باشه تا بتونه در فرمت‌های مختلف ایجاد بشه. با استفاده از الگوی طراحی Abstract Factory می‌تونیم قراردادی تعریف کنیم که مثلا فرمت یک Factory می‌تونه تمام قسمت‌ها رو برای HTML یا JSON یا XML یا PDF بسازه و در نهایت هر موقع خواستیم اون رو به هر فرمتی نمایش بدیم و جایگزین کنیم.در انتهای این هفته یک جلسه ۲ ساعته وبیناری برای رفع اشکال و پرسش و پاسخ در مورد این الگو‌ها برگزار می‌شود.

  • هفته سوم - الگوی طراحی Builder و Adapter

    در هفته سوم از این دوره به بررسی ۳ الگوی مهم Builder و Adapter می‌پردازیم. الگوی Builder در بخش Creational و الگوی Adapter در بخش Structural قرار می‌گیرد.از الگوی Builder برای ساختن اشیایی که ایجاد کردن آنها در حالت عادی پیچیدگی دارد استفاده می‌کنم. فرض کنید در یک پیام رسان قصد دارید یک پیام ایجاد کنید که مشخصات مختلفی دارد، یا مثلا یک پیام ایمیل بسیازید. در این دو حالت استفاده از Builder کار شما را خیلی راحت می‌کند. هم چنین در مواقعی که بخواید برای کلاس هاتون تست بنویسید اما اون کلاس ویژگی‌های زیادی داشته باشه که تکرار اونها در تست‌ها می‌تونه اذیت کننده باشه، باید از Builder استفاده کنید.الگوی طراحی Adapter اسمش خیلی واضحه. اگر توی نرم افزار دو تا کلاس داشته باشیم که قرارداد مشترکی نداشته باشن و نتونن با هم کار کنن خیلی راحت می‌تونیم از این الگو براشون استفاده کنیم. مثلا وقتی یه پکیج نصب می‌کنید و متدها و ساختار کلاس‌های اون پکیج با کدهای شما همخوانی نداره از این الگو می‌تونیم استفاده کنیم. حتی زمانیدر انتهای این هفته جلسه وبیناری ۲ ساعته برای پرسش و پاسخ و رفع اشکال در مورد این الگوها رو برگزار می‌کنیم.

  • هفته چهارم - الگوی طراحی Bridge و Composite

    در این هفته میریم سراغ ۲ الگوی طراحی خیلی کاربردی Bridge و Composite که یادگیری و پیاده سازیشون کدنویسی رو خیلی لذت بخش میکنه.

    الگوی Bridge یا پل توی مواقعی که کدهای یک کلاس خیلی بزرگ میشن و عملا قابلیت ایجاد کردن چند انتزاع رو دارن استفاده میشه. به عنوان مثال فرض کنید از شما میخواین برای وب سایت بخشی برای صفحات بسازید که بتونن در هر فرمت دلخواهی اون رو نمایش بدن. اینجا خیلی راحت میشه از الگوی Bridge استفاده کرد. این الگو کمک می‌کنه بین Abstraction و Implementation یک Bridge یا پل ایجاد کنیم.

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

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

  • هفته پنجم - الگوی طراحی Decorator و Facade

    خب می‌رسیم به ۲ تای دیگه از خوبای الگوهای طراحی، Decorator و Facade.

    الگوی طراحی Decorator کلا خیلی خاص و متمایز هست و به شما کمک میکنه بدون دستکاری کدهای موجود یک رفتار رو به کلاس اضافه کنید و این خیلی مزیت بزرگی محسوب میشه. فرض کنید میخواید یک سیستم فاکتور یا Invoice ایجاد کنید. در این فاکتور ممکنه اقلام و خدمات مختلفی قرار بگیرن و هر کدومشون هم قیمت خاصی داشته باشن. ما می‌تونیم با استفاده از الگوی Decorator بدون اینکه نگران باشیم محصول یا خدمات جدیدی میخواد به فاکتور اضافه بشه اون رو پردازش کنیم. این کار زحمت ما رو برای تغییر کدها خیلی خیلی کم می‌کنه و احتمال ایجاد شدن باگ در کدهای قبلی رو هم کاهش میده.

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

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

  • هفته ششم - الگوی طراحی Flyweight و Proxy

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

    ما همیشه در نرم افزار با محدودیت منابع روبرو هستیم و در دنیای شی گرایی هم اشیاء بسته به داده‌ها و نوع اونها بخشی از RAM رو اشغال می‌کنن. اگر در برنامه ای مجبور باشیم تعداد زیادی شی داشته باشیم اونوقت ممکنه این دردسر ساز بشه و برای این مشکل می‌تونیم از الگوی FlyWeight استفاده کنیم. فرض کنید در یک بازی که در مرورگر اجرا میشه باید آیتم‌های مختلفی رو قرار بدین و این آیتم‌ها هر کدومشون یک شی هستن که داده‌های زیادی دارن. با استفاده از این الگو و قرار دادن اطلاعات مشترک در کلاس‌های مجزا کمک می‌کنیم مصرف منابع برای این شی‌های زیاد بهینه بشه.

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

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

  • هفته هفتم - الگوی طراحی Chain of Responsibility و Command

    در این هفته ۲ تا از الگوهای خوب و خوشگل رو میخوایم کار کنیم و یاد بگیرم.

    الگوی Chain Of Responsibility کاربردهای زیادی در حل مسائلی داره که نیازه عملیات هایی به صورت پشت سر هم اجرا و بررسی بشه. مثلا فرض کنیم در یک نرم افزار باید مشخص کنیم چه کاربری به یک بخش دسترسی داره و در این نحوه دسترسی شرایط و حالت‌های مختلفی وجود داره. اگر بخوایم به صورت ساده بنویسیم کدهای ما پر میشه از شرط‌های کر کثیف که هیچکی حاضر نیست نگاش کنه. برای حل این مورد خیلی راحت با استفاده از این الگو می‌تونیم مشکل رو حل کنیم. یا مثلا فرض کنید ازتون خواسته شده سرویسی بنویسید که یک تماس صوتی رو بر اساس شرایط خاصی به یک اپراتور خاص وصل کنه. در این حالت هم نیاز داریم تا از این الگو استفاده کنیم در غیر این صورت بازم با کدهای کثیف زیادی کار رو تموم می‌کنیم.

    الگوی طراحی Command یکی از الگوهای محبوب هست که واقعا مارو از تکرار کد یا Duplicate Code نجات میده. فرض کنید میخواید یک سرویس برای ثبت سفارش بنویسید، اولش میگن این سرویس قرار توی وب سایت استفاده بشه و بعد از مدتی میان میگن از طریق موبایل هم باید فرخوانی بشه و شما میای و اون رو کپی می‌کنی در بخش موبایل و فردا پس فردا هم میگن این برای برای سفارش تلفنی هم بتونه کار کنه، در این موقع شما برای بخش سفارش تلفنی هم کد رو کپی می‌کنی و اگر بخوای کدها رو تغییر بدی پوستت کنده میشه. در این حالت کافیه از الگوی طراحی Command استفاده کنی تا به بهترین شکل ممکن سرویس رو پیاده سازی کنی و کدهای تکراری هم نداشته باشی.

    در انتهای این هفته جلسه وبیناری پرسش و پاسخ و رفع اشکال برای الگوهای طراحی Command و Chain of Responsibility رو برگزار می‌کنیم.

  • الگوی طراحی Observer و State

    در این هفته به بررسی ۲ الگوی دیگه که برای مدیریت اطلاع رسانی و وضعیت‌ها استفاده میشن می‌پردازیم.

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

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

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

  • الگوی طراحی Strategy و Template Method

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

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

    الگوی طراحی Template Method خیلی شبیه به Strategy هست با این تفاوت که در Strategy ما روش انجام کار کلا با روش‌های دیگه فرق داره. اما در Template Method بخشی زیادی شبیه هم هستن و یه بخش کوچیکی با هم تفاوت داره. در این روش از Template Method استفاده می‌کنیم. خیلی مهمه این لایه مرزی رو تشخیص بدیم و در این هفته قراره این رو انجام بدیم.

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

  • الگوی طراحی Visitor و Mediator

    در این هفته می‌ریم سراغ الگوهای محبوب Visitor و Mediator که کاربردهای جالبی دارن.

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

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

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

  • وبینارها

همه برنامه‌های ما شامل

ضمانت بازگشت وجه
ضمانت بازگشت وجه خرید و ثبت نام شما در دوره‌های بلندمدت سون لرن بدون ریسک مالی خواهد بود
آموزش مهارت محور
آموزش مهارت محور از مدرسین متخصص و با تجربه در بهترین شرکت‌های ایران مهارت مورد نیاز بازار کار را یاد می‌گیرید
رفع اشکالات و پشتیبانی فنی
جامعه برنامه نویسی فعال پشتیبانی و پاسخ به سوالات خود را در جامعه برنامه نویسی فعال سون لرن دریافت می‌کنید
ارزیابی فنی و رتبه بندی
ارزیابی فنی و امتیازدهی برای فعالیت‌ها و آزمون‌های خود، امتیازات مختلفی برای ارزیابی مهارت دریافت می‌کنید (از آذر 1402)
معرفی برترین‌ها به بازار کار
معرفی برترین‌ها به بازار کار دانشجویان فعالی که مستمر و منظم محتوای دوره‌ها را دنبال می‌کنند، در اولویت معرفی به بازار کار هستند
۱ سال پشتیبانی پس از خرید
۱۲ ماه پشتیبانی پس از خرید تا ۱۲ ماه پس از ثبت نامتان، در جامعه برنامه نویسی سون لرن، پشتیبانی ویژه دریافت می‌کنید
دسترسی دائمی و بدون محدودیت
دسترسی راحت و همیشگی در صورتی که در یک سال اول دوره را تکمیل نمایید، دسترسی محتوای دوره برای شما همواره باز خواهد بود

دانشجویان سابق متخصص سون‌لرن
کجا استخدام شدند؟

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


کافه بازار دیجی کالا زرین پال همیار اسنپ فود ایرانخودرو ژاکت
+ ۳۴۰ شرکت مطرح دیگر

مدرس و منتورهای دوره

کیوان علی محمدی

کیوان علی‌محمدی

مهندس نرم افزار در شرکت LTP (هلند)
مهندس نرم افزار در شرکت LTP (هلند) Technical Team Lead در شرکت اسنپ فود مهندس نرم افزار در سون لرن مهندس نرم افزار در شرکت کسب و کار ایرانیان - چیلیوری توسعه دهنده فول استک PHP و JavaScript در استارتاپ فول فکر 9 سال تجربه حرفه ای در توسعه نرم افزارهای تحت وب سابقه تدریس مدرس ۲ دوره متخصص لاراول سون لرن مدرس دوره متخصص جاوااسکریپت سون لرن مدرس ۳ دوره متخصص وردپرس سون لرن تدریس بیش از 22000 هزار نفر/ساعت دوره و کارگاه حضوری تولید بیش از 11000 هزار ساعت آموزش ویدیویی برنامه نویسی وب
لقمان آوند
لقمان آوند مدرس مهمان

ویدیو‌های نمونه تدریس دوره

امروز شروع کنید

ثبت‌نام در دوره

سوالات متداول

برای یادگیری دیزاین پترن‌ها از کجا شروع کنیم؟ آیا پیش‌نیاز خاصی دارد؟

قبل از شروع آموزش دیزاین پترن‌ها باید یکی از زبان‌های برنامه نویسی شی گرایی را بلد باشید. البته الزاما الگوهای طراحی در زبان‌های شی گرا استفاده نمی‌شود در زبان هایی که شی گرا نیستند (زبان‌های functional) هم استفاده می‌شوند.


یادگیری دیزاین پترن‌ها برای من چه مزیتی دارد؟

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

یادگیری الگوهای طراحی برای چه افرادی مناسب است؟

یادگیری دیزاین پترن‌ها برای افرادی که در حوزه توسعه نرم افزار کار می‌کند مناسب است. مهم نیست که شما در چه پارادایمی (functional یا object oriented) کار می‌کنید. تسلط بر الگوهای طراحی باعث می‌شود بتوانید کدهای بهتری را طراحی کنید. کدهایی که قابلیت تست پذیری، خوانایی، توسعه پذیری، نگه داری بالاتری دارند. و قطعا افرادی که به الگوهای طراحی مسلط هستند موقعیت‌های شغلی و درآمد بهتری دارند.


کاربرد Design Patternها چیست؟

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

الگوی طراحی چیست؟

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

انواع Design Pattern‌ها چیست؟

الگوهای طراحی سه دسته اصلی دارند:

  • Creational patterns: معمولا راه حل هایی برای ایجاد کردن آبجکت‌ها (objects) ارائه می‌دهند. تا کدهایی داشته باشیم که قابلیت reuse داشته باشد.
  • Structural patterns: کمک می‌کنند ساختارهای بزرگتری ایجاد کنیم در حالی که انعطاف پذیری و بهینه بودن حفظ شود.
  • Behavioral patterns: این دسته به الگوریتم‌ها و نحوه انجام کار و responsibility بین آبجکت‌ها مرتبط است و زا این طریق به حل مسئله کمک می‌کند.

آیا یادگیری دیزاین پترن‌ها برای برنامه نویس‌های تایپ اسکریپت ضروری است؟

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

بهترین روش یادگیری دیزاین پترن‌ها چیست؟

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

همیشه قبل از شروع یادگیری برنامه نویسی این دو سوال مطرح می‌شود:

  • آیا بهتر است به صورت self study یاد بگیریم یا یک مشاور و یک منبع جامع داشته باشیم؟ واقعیت این است هر دو روش شما را به هدف‌تان می‌رساند اما زمان رسیدن متفاوت است. ممکن است یادگیری هر زبان برنامه نویسی به صورت self study بین ۲ تا ۳ سال زمان نیاز داشته باشد. ولی اگر یک منبع آموزشی جامع با مدرس باتجربه داشته باشید که حتی پاسخگوی سوالات شما باشد آن مسیر ۳ ساله می‌تواند به یکسال تبدیل شود. من توصیه می‌کنم که اگر زمان برای شما مهم است مسیر دوم را انتخاب کنید.
  • به چه صورت برای یادگیری برنامه نویسی اقدام کنیم که نتیجه بهتری بگیریم؟ واقعیت این است که برنامه نویس بهتر کسی است که قدرت حل مسئله بهتری دارد. و این توانایی با حل مسئله و چالش‌پذیری به دست می‌آید. پس بهتر است در طول یادگیری تمرین کنید، برای خودتان پروژه تعریف کنید و در قالب پروژه چالش‌هایی را برای خودتان طرح کنید و آن چالش‌ها را در کنار آموز‌ش‌هایی که می‌بینید حل کنید. مواردی که در فرآیند چالش‌ها یاد می‌گیرید محال است که فراموش کنید.

پس اگر با یک مدرس با تجربه و معتبر و تمرین و چالش‌پذیری یادگیری را شروع کنید مطمئن باشید بهترین نتیجه را می‌گیرید.