بر هیچ کسی پوشیده نیست که گریدی بوچ واقعا از معرفترین و شناخته شده ترین صاحبنظران در مورد مدل شی گرا در جهان است.آنچه که من در مقاله قبلی نوشتم شاید بتوان بیشتر از دید برنامه نویسی به آن نگاه کرد ، در حالی که گریدی بوچ تمام ابعاد را نگاه می کند ،از تحلیل و طراحی و برنامه نویسی همه را شامل می شود . مقاله من فقط در مورد بخشی از دید شی گرایی در برنامه نویسی است .و اما هدف از این نگارش
در مقاله قبلی خودم باعنوان شی گرایی چیست ، دوستی عزیز نظری نوشته بود که نقل قولی از گریدی بوچ بود . خواستم چند مطلبی اضافه کنم.
حقیقتش اگر بخواهیم دنیای شی گرا را از دیدگاه گریدی بوچ مقایسه کنیم ، باید کتاب جامعی در این مورد نوشته شود اما من مطالب را مختصرا به شکل زیر نقل می کنم :
ازدید گریدی بوچ ارکان مدل شی دارای 4 عنصر اصلی و 3 عنصر فرعی است که به شکل زیر:
الف – عناصر اصلی
1-تجرید (abstraction) : در واقع به نگاه ؛ یک ناظر تاکید می کند ، یعنی هر ناظر در دید تحلیلی خود هر شی را چگونه می بیند هر ناظر چگونه با درک خود آن شی را در دید مفهومی خود از دیگر اشیا متمایز می کند .در اینجا ما از دید تحلیل و طراحی نگاه می کنیم نه از دید برنامه نویس .
2-در برگیری (encapsulation) : همانطور که در مقاله قبلی گفتم فرایند مخفی نگه داشتن تمام جزییات یک شی است . شامل طراحی و تحلیل و برنامه نویسی است .
3-مولفه ای بودن (modularity) : در حقیقت همان مولفه ای بودن سیستم است که منجر به تفکیک سیستم به مولفه های منسجم می کند ، به نظر من در هر سه دیدگاه تحلیل و طراحی و برنامه نویسی وجود دارد.
4-سلسله مراتب (hierarchy) : ما در بحث شی گرایی می دانیم که ممکن است کلاسی شامل کلاسی دیگر باشد و یا کلاسی از کلاس دیگر ارث بری کند . در واقع می توان گفت سلسله مراتب کلاسها هم شامل رابطه شمول و هم وراثت است . و در هر سه دیدگاه طراحی و تحلیل و برنامه نویسی کاربرد دارد.
ب- عناصر فرعی
1-نوع بندی (typing) : در واقع طبقه بندی اشیا است یعنی اگر شیی از کلاس a باشد و شیی از کلاس b داشته باشیم این اشیا متفاوت بدلیل نوع بندی کلاسهای متفاوتشان ، از هم متمایز هستند و در واقع از تداخل تجریدها یعنی از تداخل نوع نگاهها و نگرشهای ناظر جلوگیری می کند ، یعنی ناظر نمی تواند اشیا از کلاسهای متفاوت را در هم بیامیزد.
2-توازی یا هم موجودی (concurrency) : مفهومی است که بیشتر در دنیای برنامه نویسی شی گرا استفاده می شود ، در واقع یعنی استفاده از اشیا مختلف بصورت همزمان .
3-ماندگاری (persistense) : در دنیای برنامه نویسی شی گرا وقتی ما شیی را از یک کلاس ایجا د می کنیم ،آن شی مقداری از فضای حافظه را اشغال می کند . شما با استفاده از خصوصیت ماندگاری مشخص می کنید که چه وقت یک شی ایجاد شود و حافظه به آن اختصاص می یابد و چه وقت آن شی خاتمه می یابد و یا از بین می رود تا دوباره آن فضای حافظه آزاد شود .
و اما سخن آخر
در واقع گرید بوچ در تبیین مدل شی گرایی همه جوانب تحلیل و طراحی و برنامه سازی را در نظر می گیرد که در نوع خود دیدگاهی وسیع و پر محتوایی است .
در طی ده ها سال از ایجاد و بکارگیری کامپیوتر تاکنون در زمینه های مختلف ، کامپیوتر پیشرفت چشمگیری داشته است.
در نرم افزار،از برنامه های به زبان ماشین به نرم افزارهای هوشمند و زبانهای نسل چهارم رسیده ایم.کاربرد کامپیوتر و نرم افزار در تمام سطوح فراگیر شده است . و نیازهای بشری به شدت گسترش پیدا کرده است و کامپیوتر در تمام زوایای زندگی بشر رسوخ کرده و خواهد کرد ، در چنین وضعیتی لازم است:
1-همه افراد توانی ها و سواد کامپیوتری لازم را داشته باشند .
2-کسانیکه در رشته کامپیوتر فعالیت می کنند باید با ایده ها و روشها و تکنیکهای جدید آشنایی کامل داشته باشند ، یکی از این ایده ها ، برنامه نویسی شی ء گرایی است .
همچنین نیازهای جوامع بشری به شدت گسترش پیدا کرده است . و همین موجب مطرح شدن مفهوم ((سامانه پیچیده )) و ((سیستم پیچیده )) شده است . اغلب پدیده های طبیعی و بسیاری از ساخته ها و آفرینشهای امروزین بشر را باید تحت عنوان رده عام – سامانه پیچیده یا سیستم پیچیده (complex systems) به بررسی و مطالعه نشست . مثالهای زیادی را می شود برای این سامانه ها ذکر کرد مانند سامانه اقتصاد یا سامانه کارت سوخت و انرژی
سیستمهای پیچیده :سازمانها مصداق کامل سیستمهای پیچیده هستند ، پیچیدگی سیستمها نه فقط به تعدد و تنوع اجزای سیستم و متغیرهای اثر گذار بر رفتار آنها مربوط می شود . بلکه به تنوع ارتباطات فیما بین اجزاء و محیط از سویی و به متغیر بودن جهت و شدت تاثیرات متقابل و تعاملات بین اجزاء و محیط از سوی دیگر مربوط است .
مدیریت بر سیستمهای پیچیده مستلزم درک این پیچیدگیها و این ویژگیها است .در این سیستمها بجای تمرکز بر نقطه بروز مساله و سعی در زدودن نشانه های مساله ، باید بر رفتار سیستم پدید آورنده مساله تمرکز کرد .
در این سیستمها ، آنچه مهم است (( چه باید باشد )) و ((چگونه باید باشد )) مهم است . مهندسان نرم افزار در تحلیل سیستمهای پیچیده می باید چگونگی و چرایی رفتار آن سیستم را نه فقط بررسی کنند بلکه باید این چگونگی و چرایی را به تصویر بکشند و در نهایت بصورت نرم افزار در آورند.
پیچیدگی نرم افزارهای مورد تقاضا روز به روز بیشتر می شود در حالی که ما در برخورد با این پیچیدگیها بطور بنیادی محدود هستیم . ما چه خواهیم کرد راه کار چیست ؟
تنها یک راه وجود دارد و آن هم استراتژی غلبه بر پیچیدگیها و به نظم در آوردن آشفتگی
روش چیره شدن بر پیچیدگیها از زمان قدیم شناخته شده است . فاصله بینداز و پیروز شو .
در مواقع طراحی یک سیستم نرم افزاری پیچیده ، تفکیک آن به قسمتهای کوچک و کوچکتر بسیار ضروری است . به گونه ای که بتوانیم هر یک را بطور مستقل مورد توجه قرار دهیم.
از این رو پس از گستردگی سیستمهای پیچیده ، مهندسی نرم افزار دستخوش تغییرات فراوانی شد ، و روش توسعه نرم افزار مبتنی بر کد نویسی خط به خط با توسعه مبتنی بر شی ء یا مؤلفه جایگزین شد.
تعریف کلی شی :
مؤلفه های نرم افزاری یک قطعه جامع و قابل توسعه می باشد که عملکردش به خوبی تعریف شده است و از طریق واسطها با دیگر مؤلفه ها می تواند ترکیب شده و با همدیگر در تعامل باشند.
سه هدف اصلی برنامه نویسی مبتنی بر اشیاء:
*غلبه بر پیچیدگی * مدیریت تغییر * قابلیت استفاده مجدد.
غلبه بر پیچیدگی: ما در یک دنیای پیچیده ای از عصر انفجار اطلاعات زندگی می کنیم .طبق تحقیقات انجام گرفته توسط تیمی در دانشگاه برکلی : دنیا ما بین یک و دو اگزا بایت اطلاعات بی نظیر در هر سال تولید می کند که تقریبا 250 مگا بایت برای هر مرد ، زن و بچه در روی زمین است . هر اگزا بایت یک بیلییون گیگا بایت است . در علم کامپیوتر اندازه پیچیدگی نرم افزار به طور قابل توجه در حال افزایش است .. برنامه نویسی مبتنی بر مولفه یک روش موثر با نام تقسیم و غلبه را برای برخورد با پیچیدگی نرم افزار فراهم می کند.
مدیریت تغییر:تغییرات در مهندسی نرم افزار ذاتی است ، تغییر خواسته های کاربران ، تغییر مشخصه ها ، تغییر کارکنان ، تغییر بودجه ، تغییر تکنولوژی و غیره.یکی از اهداف اساسی مهندسی نرم افزار تاکید بر اهمیت مدیریت تغییر می باشد.برنامه نویسی مبتنی بر مولفه یک روش موثر به نام برنامه ریزی برای تغییر و ساخت طراحی را برای برخورد با تغییرات در مهندسی نرم افزار فراهم آورده است . مولفه ها به آسانی با خواسته های جدید و در حال تغییر وفق داده می شوند .
قابلیت استفاده مجدد: نرم افزار با قابلیت استفاده مجدد باعث می شود که طراحی و پیاده سازی فقط یکبار انجام گیرد و در زمینه ها و قلمرو های متفاوتی بارها و بارها مورد استفاده قرار گیرد که قابلیت استفاده مجدد باعث افزایش بازدهی ، بکارگیری مفید از راه حلهای ارائه شده ، اصلاح کیفیت و غیره می باشد. سطوح مختلفی از قابلیت استفاده مجدد نرم افزار وجود دارد برای نمونه کپی کردن کد منبع ، که پایین ترین سطح از قابلیت استفاده مجدد می باشد. کتابخانه ای از توابع رویه ای بهتر از کپی کد منـبع می باشد اما توسعـه پذیر نیست. برنامه نویسی مبتنی بر مولفه سطح بالایی از استفاده مجدد نرم افزار را پشتیبانی می کند. به خاطر اینکه در برگیرنده انواع گوناگونی از استفاده مجدد می باشد.
پس دانستیم که بنابر توضیحات بالا به هنگام مواجهه با سیستمهای پیچیده و بزرگ باید با دید شی گرایی به سیستم نگاه کنیم ، فایده این روش در آن است که ریسک تولید سیستمهای بزرگ را کاهش می دهد به دلیل آنکه طراحی این سیستمها به گونه ای است که بتوانند از سیستمهای کوچکتر که ما در مورد آنها مطمئن هستیم به سیستمهای بزرگتر می رسیم .
اکنون سوال مطرح می شود که در برخورد با سیستمهای پیچیده چگونه بادید شی گرایی کار کنیم و اجزای اصلی دیدگاه شیء گرایی چیست ؟
در دیدگاه شیء گرایی ما با سه مقوله مواجه هستیم .
1-برنامه سازی شی گرایی (Object-oriented programming)
2-طراحی شی گرایی (Object-oriented design)
3-تحلیل شیء گرایی (Object-oriented analysis)
برنامه نویسی شیء گرایی
یک شیوه برنامه نویسی است که در آن برنامه ها بصورت مجموعه ای از اشیاء که با یکدیگر همکاری می کنند ، سازمان داده شده اند .اشیاء صورتهای مجرد از ماهیتهای مطرح در مسئله هستند که دارای وضعیت (درونی) و همچنین عملیات بر روی دادهها (وضعیت درونی) میباشند.
طراحی شی گرایی
طراحی شیء گرا بر یک پایه مهندسی محکم که مجموعه عناصرش را مدل شیء می نامیم ، بنا شده است . طراحی شی گرایی با دیدگاه سنتی طراحی ساخت یافته متفاوت است ، در این تکنیک ما با اشیا ، سر و کار داریم طراحی شیء گرا بر مباحثی نظیر: شیء، کلاس، مسئولیت، عمل و سناریو استوار است و جهان را به صورت مجموعه ای از اشیاء به هم مرتبط می بیند که هر شیء، رفتار خاص خود و مسئولیت خاص خود را دارد.
فرآیندی است که برای درک سیستم با استفاده از کلاسها و اشیایی که در جهان با آن سیستم مرتبط هستند ، استفاده می شود . در واقع تحلیل گر در این حالت همه اجزا سیستم را بصورت شی ء می بیند و تفکیک می کند ، و براساس قوانین دنیای شی گرایی ، ارتباط بین اشیا را ایجاد می کند.
نحوه ارتباط 3 عنصر بالا با یکدیگر:
اصولا حاصل تحلیل شی گرا به عنوان مدلی که از آن می توانیم طراحی شی ء گرا را آغاز کنیم ، می تواند عمل کند سپس حاصل طراحی شی گرا ، می تواند برای پیاده سازی کامل سیستم ، با استفاده از روشهای برنامه نویسی شی گرا مورد استفاده قرار می گیرد . شکل زیر گویای مسله است
تحلیل شی گرا ------------> طراحی شی گرا-----------> برنامه نویسی شی گرا
سه رکن بنیادی شی گرایی
1-کپسوله سازی (encapsulation)
2-وراثت (inheritance)
3-چند شکلی بودن (polymorphism)
1-کپسوله سازی : فرآیند مخفی نگاه داشتن تمام جزییات از یک شی است که مشارکتی در ویژگیهای اصلی شی نداشته باشند . به شکل زیر نگاه کنید ، شما در فرایند کپسوله سازی از جزییات شی خود بی خبرید
-وراثت : یک سلسله مراتب میان کلاسها در سیستمهای شی گرا است . وراثت تشبیهی از دنیای واقعی وراثت موجود است ، کلاس فرزند می تواند خصوصیات کلاس پدر را به ارث ببرد.
3-چند شکلی بودن : یعنی اینکه یک موجودیت ، دارای اشکال مختلفی باشد. و یا به تعبیری با استفاده از یک نام واحد بتوان رفتارهای مختلفی را در شرایط مختلف آن هم بصورت خودکار انتظار داشت .
برای درک دو مورد بالا به شکل زیر دقت کنید ، ما یک مجموعه حیوانات داریم خوب همه آنها حیوان هستند ، پس می توان یک کلاس والد یا پدر به نام حیوان داشته باشیم که بقیه کلاسها مانند ، شیر ، سگ و گربه و غیره از آن مشتق شده باشند یا به تعبیری از آن ارث بری می کنند یعنی کلاس شیر باید خاصیت کلاس حیوان را به ارث ببرد .
نکاتی ساده اما کاربردی
موضوعی که می خواهم در مورد آن بنویسم بیشتر به بحث خطایابی نزدیک است . همه برنامه نویسان با این مشکل روبرو هستند که هر نسخه از نرم افزار که ارایه می دهند ، ممکن است باگهایی داشته باشد ، که باید آنها را اصلاح کرد و نسخه جدیدی ارایه دهند .اما در فرآیند دیباگ نرم افزار و انتشار مجدد آن نکاتی وجود دارد که باید به آنها توجه کنیم . سعی می کنم به مهمترین این نکات اشاره کنم.
1-سعی کنید یک بانک اطلاعاتی از توابع برنامه خودتان داشته باشید . مثلا
نام تابع --پارامترهای ورودی ---اهداف تابع ---مقادیربازگشتی ---و از همه مهمتر نحوه ارتباط این تابع با توابع دیگر ،
فایده این کار در این است که اگر خواستید تابعی را تغییر دهید . متوجه خواهید شد که این تابع با چه توابع دیگری در ارتباط است . و در نتیجه عملکرد تغییر را کنترل می کنید .
2-نمودار کلاسها و ارتباطات بین آنها
علاوه بر توابع ، شما باید دقت کنید که ارتباط کلاسهای شما چگونه است . اگر کلاسی دچار تغییر شد ، کدام کلاسهای دیگر نیز باید تغییر کنند.
3-حفظ و نگه داری نسخه های قبلی
حتما قبل از هر تغییر در سورس نرم افزار حتما و حتما از آن پشتیبان بگیرید . همچنین اگر از ابزارهای کنترل سورس استفاده نمی کنید . می توانید یک راه حل ساده برای تمایز نسخه های برنامه استفاده کنید ، شما در عنوان صفحه اصلی برنامه می توانید شماره نسخه را وارد کنید
4-مدیریت خطاها
حتما با دستورات کنترل خطاها کار کرده اید . هر جا که خطایی در برنامه ایجاد شد یک پیغام نمایش می دهد. برای اینکار شما برای هر خطا یک کد یا شماره اختصاص دهید تا به هنگام مشاهده آن پیغام ، براحتی بتوانید محل وقوع خطا را پیدا کنید .