اگر در حال مطالعه این مقاله هستید تصمیم گرفتهاید پا به دنیای برنامهنویسان حرفهای بگذارید. به شما تبریک عرض میکنم.
حالا چرا دنیای برنامهنویسان حرفهای؟
چون معمولاً افراد آماتور از مفاهیمی چون دیزاین پترنها استفاده نمیکنند و افراد حرفهای هستند که به دنبال آموزش دیزاین پترنها میباشند.
ابتدا دیزاین پترن ها را تعریف کنیم
دیزاین پترن چیست؟
دیزاین پترنها راهحلهای اثبات شدهای برای حل مشکلات پروژههای نرمافزاری هستند و این یعنی این که شما مجبور نیستید برای چالشهای که در پروژهها دارید خودتان راهحل جدیدی ارائه کنید و میتوانید از راهحلهای موجود که به آنها دیزاین پترن یا الگوهای طراحی گفته می شود استفاده نمایید.
شاید برای برنامهنویسان تازهکار آشنایی با دیزاین پترنها سخت و پیچیده باشد، اما واقعاً دیزاین پترنها خیلی پیچیده نیستند و بهراحتی میتوانید با این مفهوم آشنا باشید و از انواع دیزاین پترنها در پروژههای خود استفاده کنید
در ادامه این مقاله شما را کامل با مفهوم دیزاین پترن آشنا میکنیم
برای آشنایی کامل با دیزاین پترن ها آموزش دیزاین پترن ها در #C رو در سایت ببینید.
بررسی یک چالش در پروژههای نرمافزاری
در پروژههای نرمافزاری چالشها و مشکلات متعددی وجود دارد و شما بهعنوان یک برنامهنویس و یا طراح سیستم باید راهحلهایی برای حل این مشکلات ارائه کنید.
فرض کنید شما بهعنوان یک مدیر فنی در یک شرکت طراحی نرمافزار مشغول به کار هستید و تیم شما در حال طراحی یک نرمافزار واژهپرداز مثل Office Word میباشد.
حالا نیاز کارفرما این است که در این نرمافزار واژهپرداز قابلیتهای Undo/Redo هم اضافه شود و شما بهعنوان مدیر فنی باید بهترین راهحل، برای پیادهسازی این قابلیتها رو ارائه کنید.
فرض ما بر این است که شما و اعضای تیم تابهحال در هیچ نرمافزاری قابلیتهای Undo/Redo را پیادهسازی نکردهاید و با نحوه پیادهسازی همچنین قابلیتهایی آشنایی ندارید.
شما با یک چالش جدید روبهرو شدهاید و مجبورید راه حلی برای غلبه بر این چالش ارائه کنید.
شاید شما هم تجربه این را داشته باشید که بعد از مواجه شدن با یک چالش یا یک باگ در برنامه، روشهایی رو پیادهسازی کنید که مشکل برطرف شود و برنامه بتواند بهدرستی کار کند. ولی از طرفی مشکلاتی برای نگهداری و توسعه برنامه برای ما ایجاد کند. اما در تیمهای بزرگ هدف فقط اجرای درست برنامه نیست!
راهحل ارائه شده توسط شما باید بتواند به این سؤالها پاسخ مثبت دهد:
- آیا در آینده توسعه برنامه را بدون مشکل میتوانیم انجام دهیم؟
- این راهحل انعطافپذیر هست؟آیابعد از پیادهسازی این راهحل سیستم ما Reusable هست؟
- استفاده مجدد از کدها بالاتر میرود؟
- با این راهحل طراحی برنامه بهتر میشود؟
- آیا کدنویسی تمیزی انجام شده؟
- این راهحل مورد پذیرش اعضای تیم هست؟ و همه اعضای تیم میتوانند آن را بهخوبی درک کنند؟
- میتوانیم راه حلی که استفاده کردهایم را ضمانت کنیم؟ آنقدر به راهحل اعتماد داریم که بتوانیم قاطع بگوییم این بهترین راهحل این مشکل است؟
- هر راه حلی که ارائه میکنید باید به این سؤالات پاسخ دهد و به این صورت میتوانیم تشخیص دهید که راهحل مناسبی ارائه کردهایم یا خیر؟
- حالا شما بهعنوان مدیر فنی تیم توسعه میتوانید در سریعترین زمان ممکن یک راهحل مناسب برای قابلیتهای Undo/Redo به تیم ارائه بدهید؟ راه حلی که بتواند به سؤالات بالا پاسخ مثبت بدهد؟
اگر الان راه حلی به ذهن شما نمیرسد احساس ناامیدی نکنید. شاید ارائه همین راه حلی توسط یک نفر و در مدتزمان کوتاهی کار نشدنی باشد. یا لااقل به زمان زیادی برای تحقیق و توسعه نیاز داشته باشد.
خب حالا که ما نمیتوانیم خیلی سریع یک راهحل مناسب برای این مشکل ارائه کنیم باید چه کاری انجام دهیم؟
مشکل شما با استفاده از دیزاین پترنها برطرف میشود باید از یک دیزاین پترن که مخصوص این کار ارائه شده است استفاده کنید.
چرا از دیزاین پترنها استفاده کنیم؟
معمولاً یک الگوی طراحی توسط یک فرد خاصی ارائه نشده و معمولاً حاصل تلاش صدها برنامهنویس در تیمهای مختلف که طی سالیان برای مقابله با یک مشکل خاص بارها و بارها استفاده شده و در نهایت توانسته با یک راهحل مناسب برای مقابله با آن مشکل تبدیل شود و الان بهعنوان یک الگوی طراحی میتوانیم از آن روش خاص استفاده کنیم.
این دیزاین پترنها حاصل تلاش و تجربه صدها برنامهنویس میباشند و در هزاران پروژه مختلف توسط تیمهای زیاده استفاده شده است و به همین دلیل ما میتوانیم بهدرستی این راهحلها اعتماد کنیم
با استفاده ازالگوهای های طراحی موجود برای رفع مشکلات صرفهجویی قابلتوجهی در زمان و هزینه میشود و میتوانیم طراحی مناسبی در پروژههای خود به دست بیاوریم
معروفترین دیزاین پترنها کداماند؟
در همان سالهای ابتدایی تیمهای برنامهنویسی برای اجرای پروژههای مختلف در اقصینقاط دنیا شروع به فعالیت کردند الگوهای طراحی زیادی توسط تیمها و افراد مختلفی ارائه شدند. اما تعداد کمی از این دیزاین پترنها محبوب شدند و توسط افراد زیاد مورداستفاده قرار گرفتند.
در سال 1994 برای اولینبار چهار نفر تصمیم گرفتند از میان دیزاین پترنهای ارائه شده تا آن زمان محبوبترین و پرکاربردترین دیزاین پترنها را در کتابی به نام Design Patterns: Elements of Reusable Object- Oriented Software جمع آوری کنند.
آقایان اریک گاما، ریچارد هلم، رالف جانسون، جان ولیسیدس افرادی بودند که این کتاب را نوشتند که بعدها به چهار گانگستر یا gang of Four معروف شدند و الگوهای طراحی که در این کتاب جمعآوریشده نیز به دیزاین پترنهای GOF معروف شدند.
در مقاله کدام دیزاین پترن ها در برنامه نویسی معروف هستند؟ دیزاین پترن های معروفی که برنامه نویس ها بیشتر از آنها استفاده میکنند را معرفی کرده ایم.
در این کتاب 23 دیزاین پترن در سه دسته ارائه شدند. با این که از زمان ارائه این دیزاین پترنها سالها میگذرد اما همچنان این دیزاین پترنها مورداستفاده قرار میگیرند و در همین وبسایت باگتو تا به امروز حداقل از 3 دیزاین پترن Gof استفاده شده است.
البته بعد از سال 1994 دیزاین پترنهای دیگری هم ارائه شدند که کاربردهای زیادی در برنامهنویسی دارند و امروزه هم از دیزاین پترنهای Gof استفاده میشود و هم از دیزاین پترنهای جدیدی که ارائه شدهاند.
دیزاین پترنهای ساختاری(Structural Design Patterns)
دیزاین پترنهای ساختاری به این موضوع میپردازند که چگونه کلاسها یا شیءها را میتوان با یکدیگر ترکیب یا همجمع کرد تا ساختارهای جدید ایجاد شود.
دیزاین پترنهای ساختاری شامل:
- Adapter (تطبیق دهنده -هماهنگ ساز ): یک رابط بین دو کلاس ناسازگار را ایجاد میکند، به طوری که یک کلاس بتواند از توابع یک کلاس دیگر استفاده کند.
- Bridge (پل): انتزاع از پیادهسازی جدا کرده و به طوری آنها را مستقل میکند که هر دو میتوانند به صورت مستقل تغییر کنند.
- Composite (ترکیبی): به شیءها امکان میدهد تا به شکل ساختار درختی سازماندهی شوند و به شیء تکی یا گروهی از شیءها به یکسان پاسخ دهند.
- Decorator (تزیینکننده): به شیء موجود ویژگیها یا وظایف اضافی را اضافه میکند.
- Facade (نمای بیرونی ): یک رابط یکپارچه برای مجموعهای از رابطها در یک سامانه فراهم میکند، و کار با سامانه را سادهتر میکند.
- Flyweight (شی سبک وزن ): فاکتور گیری از اشیائ تکراری و صرفه جویی در مصرف حافظه .
- Proxy (نماینده- واسطه ): یک شیء نماینده برای شیء دیگر فراهم میآورد تا به دسترسی به آن نظارت کند.
این الگوها به توسعهدهندگان کمک میکنند تا ساختار کد را بهبود ببخشند، مدیریت وابستگیها را بهتر کنند و با کارایی بالاتری کد بنویسند.
دیزاین پترنهای ایجادی(Creational Design Patterns)
دیزاین پترنهای ایجادی به طراحی بهتر و موثرتر نحوهی ایجاد اشیاء میپردازند. هدف از استفاده از این الگوها، جداسازی نحوهی ساخت اشیاء از نحوهی استفاده از آنها و بهینهسازی فرآیند ساخت است.
دیزاین پترنهای ایجادی شامل:
- Singleton (تک نمونه): ضمانت میکند که یک کلاس تنها یک نمونه داشته باشد و یک نقطه دسترسی به آن نمونه ارائه میدهد.
- Factory Method (روش کارخانه): واسطی تعریف میکند که از کلاسهایی که اشیاء را میسازند جدا است. به طوری که زیرکلاسها تصمیم بگیرند که کدام کلاس از آنها باید مورد استفاده قرار گیرد.
- Abstract Factory (کارخانه انتزاعی): واسطی برای ایجاد خانوادههای وابسته یا وابسته به هم از اشیاء بدون مشخص کردن کلاسهای محدد ارائه میدهد.
- Builder (سازنده): جدا کردن نحوه ساخت یک شی مرکب از نحوه نمایش آن. به این ترتیب، همان شی میتواند با انواع مختلفی از نمایشها ساخته شود.
- Prototype (نمونه اولیه): ایجاد یک نمونه اولیه کامل از یک شی و سپس کپی کردن آن شی برای ساخت نمونههای جدید.
در موارد مختلف، ممکن است نیاز به استفاده از الگوهای طراحی ایجادی متفاوت باشد. به عنوان مثال:
- زمانی که نمیخواهیم سیستم بداند چگونه اشیاء ساخته میشوند و نمایانگر میشوند.
- زمانی که سیستم باید مستقل از چگونگی ساخت و ترکیب اشیاء باقی بماند.
- زمانی که فرآیند ایجاد یک شی پیچیده است یا زمانی که ایجاد یک شی هزینهبر است و ما میخواهیم بهینهسازی کنیم.
این الگوهای طراحی، به توسعهدهندگان کمک میکنند تا نحوهی ایجاد اشیاء را به صورت موثرتر و بهینهتر مدیریت کنند، و به همین ترتیب، افزایش پذیری و قابلیت نگهداری نرمافزار را تسهیل میکنند.
دیزاین پترنهای رفتاری(Behavioral)
دیزاین پترنهای رفتاری به تعریف الگوهایی پرداختهاند که روابط، تعاملات و وظایف بین اشیاء و کلاسها را توصیف میکنند. این الگوها به توسعهدهندگان کمک میکنند تا تعاملات میان اشیاء را به طرزی مؤثر و سازماندهیشده انجام دهند.
دیزاین پترنهای رفتاری شامل:
- Chain of Responsibility (زنجیره مسئولیت): چندین شی را به گونهای پیوسته میکند تا به ترتیب، هر یک از آنها شانس پردازش درخواست را داشته باشد.
- Command (دستور): درخواست را به عنوان یک شی در نظر میگیرد، اجازه میدهد که کاربران با پارامترهای مختلف درخواستها را پارامتریزه کنند.
- Interpreter (تفسیرگر): یک گرامر برای زبان ساده را تعریف میکند و ارائه میدهد.
- Iterator (تکرارگر): دسترسی به عناصر یک اشیاء مجموعه را بدون نیاز به آشنایی با ساختار آن فراهم میکند.
- Mediator (واسطه): تعریف یک شی است که کپسولهسازی یک سری از تعاملهای بین اشیاء است.
- Memento (یادداشت): حفظ و بازیابی حالت داخلی یک شیء بدون نقض اصول کپسولهسازی آن.
- Observer (مشاهدهکننده): وضعیت یک شیء در هنگام تغییر به یک سری از اشیاء وابسته به آن اطلاع میدهد.
- State (وضعیت): اجازه میدهد یک شیء رفتار خود را زمانی که وضعیت داخلی آن تغییر میکند، تغییر دهد.
- Strategy (استراتژی): تعریف یک مجموعه از الگوریتمها، قابل تبدیل آنها به یکدیگر، و قابل استفاده بر اساس انتخاب در زمان اجرا.
- Template Method (روش الگو): تعریف ساختار یک الگوریتم در یک روش، اما تأخیر در تصمیم گیری در مورد پیادهسازی بخشهایی از آن به زیرکلاسها.
- Visitor (بازدید کننده): اضافه کردن عملیات به اشیاء بدون تغییر کلاسهایی که آنها را تعریف میکنند.
هر یک از این الگوها در موقعیتهای خاصی مورد استفاده قرار میگیرد، و به توسعهدهندگان کمک میکند تا ساختار کد را بهینهتر و قابلفهمتر کنند، و همچنین قابلیت نگهداری و توسعه نرمافزار را افزایش دهند
چه کسانی باید کار با این دیزاین پترنها را یاد بگیرند؟
دیزاین پترنها به توسعهدهندگان کمک میکنند تا با استفاده از راهحلهای آزمودهشده و استاندارد، مسائل متداول در طراحی نرمافزار را حل کنند. هر فردی که در زمینههای زیر فعالیت دارد یا به آنها علاقهمند است، باید با دیزاین پترنها آشنا باشد:
توسعهدهندگان نرمافزار: دانستن دیزاین پترنها به توسعهدهندگان کمک میکند تا کدهای با کیفیتتر، قابل توسعه و نگهداری، و همچنین با قابلیت بازاستفاده بیشتر بنویسند.
طراحان نرمافزار و معماران سیستم: برای این افراد، دیزاین پترنها ابزارهایی هستند که به آنها کمک میکنند تا ساختار مناسبی برای نرمافزارها و سیستمهایی که طراحی میکنند ایجاد کنند.
تحلیلگران نیازمندیها و تحلیلگران سیستم: این افراد میتوانند با فهمیدن دیزاین پترنها بهتر با تیم توسعه همفکری کنند و نیازمندیها و تحلیلهای خود را به صورت واضحتر ارائه دهند.
تستکنندگان نرمافزار: آشنایی با دیزاین پترنها میتواند به تستکنندگان کمک کند تا بهتر متوجه معماری و تعاملات بین بخشهای مختلف نرمافزار شوند.
دانشجویان و پژوهشگران در زمینهی علوم کامپیوتر و مهندسی نرمافزار: برای این گروه، دیزاین پترنها موضوعات پایهای در دروس مربوط به مهندسی نرمافزار هستند و میتوانند به آنها در پروژههای عملی و پژوهشهای خود کمک کنند.
در نهایت، هر کسی که مایل است توسعه نرمافزار را با یک رویکرد حرفهای تر و استانداردتر انجام دهد، باید با دیزاین پترنها آشنا شود
برای یادگیری سریع و اصولی 23 دیزاین پترنی که توسط چهار گانگستر معرفی شدند میتوانید از دوره آموزش دیزاین پترن ها در C# سایت باگتو شرکت نمایید. در این دوره تمامی 23 الگوی طراحی را به صورت کامل با مثال های عملی به شما آموزش می دهیم و بعد از شرکت در این دوره شما دانش کافی در مورد دیزاین پترنها رو بدست می آورید و در هنگام مواجه شدن با مشکلات در پروژههای خود بهراحتی نگاهی به لیست دیزاین پترنهای که یاد گرفتهاید می اندازید و مناسب ترین دیزاین پترن را برای رفع مشکل خود استفاده می کنید.
برای قابلیتهای undo/Redo از چه دیزاین پترنی استفاده کنیم؟
به چالش تیم توسعه خودمان برگردیم، حالا شما بهعنوان مدیر فنی تیم توسعه نرمافزار متوجه شدهاید که بهجای پیداکردن یک روش جدید برای پیادهسازی قابلیت Undo/Redo میتوانید از دیزاین پترنهای موجود استفاده کنیم.
و حالا باید لیست دیزاین پترنهای ارائه شده را در دست بگیرید و قابلیتهای آنها را مطالعه کنید و از بین آنها دیزاین پترنی که مناسب مشکل شما میباشد انتخاب کنید و از آن استفاده کنید که در این مورد خاص میتوانید از دیزاین پترن Command استفاده کنید.
نتیجهگیری:
دیزاین پترنها راهحلهای اثبات شدهای هستند که برای رفع مشکلات ارائه شدهاند. چون حاصل تلاش افراد و تیمهای زیادی میباشد و در پروژههای مختلفی بارهاوبارها مورداستفاده قرار گرفتهاند ما میتوانیم به این روشها اعتماد کنیم و از آنها استفاده کنیم.
و از طرفی چون یک روش عمومی میباشند که احتمالاً همه اعضای تیم با آن آشنایی دارند همه افراد تیم بهراحتی میتوانند آن را درک کنند و آن را بهدرستی به کار ببرند.
برای افزودن دیدگاه خود، نیاز است ابتدا وارد حساب کاربریتان شوید