![]() |
|
الفصل(12): Oop بالتفصيل...الجزء الثاني - نسخة قابلة للطباعة +- منتدى فيجوال بيسك لكل العرب | منتدى المبرمجين العرب (http://vb4arb.com/vb) +-- قسم : الأقسام التعليمية - المنتدى القديم (http://vb4arb.com/vb/forumdisplay.php?fid=90) +--- قسم : قسم دورات المنتدى (http://vb4arb.com/vb/forumdisplay.php?fid=113) +---- قسم : دورة تعليم البرمجة باستخدام VB.net, (http://vb4arb.com/vb/forumdisplay.php?fid=129) +---- الموضوع : الفصل(12): Oop بالتفصيل...الجزء الثاني (/showthread.php?tid=4384) |
الفصل(12): Oop بالتفصيل...الجزء الثاني - B3dak Hbebe - 23-09-12 بسم الله الرحمن الرحيم
السلام عليكم ورحمة الله وبركاته نبدا من حيث انتهينا من الفصل السابق يجب قراءة الفصل السابق لتتمكن من الاستمرار في هذا الفصل الفصل 11 وهذا الفصل ايضا كتب بقلم الاستاذ احمد نجم وراثة الواجهاتInterface Inheritance تحدثنا سالفاً عن اشتقاق او وراثة فئة من أخرى وفيها تورث الفئة المشتقة كافة خصائص ووسائل وأحداث الفئة الأب وكذلك أيضاً وراثة الكود المكتوب بالداخل كاملاً. يُمكنك Visual Basic .NET من تعريف أو التصريح عن الواجهات ، والواجهة ما هي إلا واجهة لفئة ما واسمها خير دليل على هذا وهي لا تحتوي على أية أكواد للتنفيذ. بعد تصريحك عن واجهة جديدة يمكنك استخدام الكلمة [FONT=&]Implements[/FONT][FONT=&]<InterfaceName>[/FONT] وذلك كي تشتق أو تستدعي كافة الوسائل والخصائص والأحداث التي تم التصريح عنها داخل الواجهة. كي تتضح لديك الرؤية أكثر من ذلك ، اتبع ما يلي ... قم بالتصريح عن هذين المتغيرين كما هو موضح أدناه : كود : [align=left]Dim CN1 As New System.Data.OleDb.OleDbConnectionالعجيب في هذين التصريحين أنك إذا نظرت في الوسائل والخصائص المصاحبة للكائن [FONT=&]CN1[/FONT] ستجدها بنفس الترتيب ونفس الهجاء بالنسبة للكائن [FONT=&]CN2[/FONT] ، ولكن مع اختلاف الوظيفة ... يعني مثلا الوظيفة [FONT=&]Open[/FONT] فهي مصاحبة لكلا الكائنين ولكنها مع [FONT=&]CN1[/FONT] تتصل بأي قاعدة بيانات حسب جملة الاتصال الممررة إليها [FONT=&]Connection[/FONT][FONT=&]String[/FONT] ، أما مع الكائن [FONT=&]CN2[/FONT] فهي لا تتعامل إلا مع محركات قواعد بيانات [FONT=&]MS[/FONT][FONT=&]SQL[/FONT][FONT=&]Server[/FONT] فقط بالرغم من أن اسم الوظيفة واحد في كلا الكائنين ... هنا يتضح معنى الواجهات. سأوضح لك مرة أخرى وبمثال آخر .. بفرض أنك مدير مشروع برمجي معين وليكن هذا المشروع خاص بصناعة مكتبة DLL للتعامل مع ملفات MS OFFICE ، وقد قررت كمدير مشروع أن تقوم بعمل أربعة فئات [FONT=&]4[/FONT][FONT=&]Classes[/FONT] ، الأولى منهم لـ MS Word والثانية لـ MS Access والثالثة لـ MS PowerPoint والرابعة لـ MS Excel ، وتم الاتفاق على عدة وظائف مثلا كالآتي :
وهذا فقط كان على سبيل المثال .. تعال معي نرجع سوياً إلى موضوعنا الأساسي ، أنت كمدير مشروع كما ذكرنا سالفا أنك تريد تواجد هذه الخصائص والوسائل في كل فئة من الأربعة فئات المرجو إنشائها. هل الحل أنك تقوم بالنسخ واللصق ومن ثم تغيير الأكواد ، أم الإملاء على المطورين ومن ثم تجد الأخطاء ؟؟؟ ... هنا سنلجأ إلى استخدام الواجهات فهي من ستحل الموضوع. من القائمة Project اختر العنصر Add Component ثم اختر العنصر Interface كما هو موضح بالصورة أدناه : قد قمت بالتصريح عن الوسائل والخصائص السالف ذكرها في الواجهة كما يلي ... ولا زلت أكرر أننا لا نكتب أية أكواد داخل الواجهة ، فقط نقوم بالتعريف والتصريح عن مكونات الفئة كما يلي : كود : [align=left]Public Interface MyInterfaceأنا فقط قمت بعمل مثال عابر ومبسط ، فيمكنك عزيزي القارئ أن تقوم بالتصريح عما تحب وكيف تحب ومتي تحب ... قم بالتصريح مثلا عن متغيرات عادية وأحداث ووسائل وخصائص ، أما أن لضيق الوقت أردت إيصال الفكرة فقط. أنا متشوق بالفعل حتى أريك كيف يتم وراثة هذه الواجهة داخل الفئات التي قمنا بإنشائها سابقاً ، فكل ما عليك إلا الدخول داخل كل فئة وتكتب هذه العبارة : كود : [align=left]Implements MyInterface[b][FONT=Tahoma]ستجد نفسك في الفئة مثلا الخاصة بالـ MS Excel قد حصلت على النتيجة التالية كوراثة حقيقية لما تم التصريح عنه في الواجهة [FONT=&]MyInterface[/FONT]: كود : [align=left]Public Class Excel هذه هي بالفعل شكل الفئة بعد وراثة الواجهة وما عليك إلا توزيع الهيكل العام لهذه المكتبة DLL على المطورين في المشروع وهم يقوموا بكتابة الكود فقط داخل الوسائل والخصائص والأحداث المصرح عنها ... يمكنك تحميل المشروع من الرابط التالي : http://www.4shared.com/rar/8gCjzUtj/21250864124.html أو من المرفقات بإسم : مرفق 1 ** ملحوظة ** كما ذكرنا سابقاً أن Visual Basic .NET لا يسمح لك بالوراثة من أكثر من فئة ، ولكن داخل الفئة الواحدة يمكنك وراثة أكثر من واجهة. كلمة أخيرة في مبدأ الوراثة .. الكلمات المفتاحية
[FONT=&]Access Modifiers[/FONT]
يمكنك مراجعة المثال التالي ، فهو عبارة عن فئة بالاسم ( MyClass ) وبها بعض الإجراءات باختلاف الكلمات المفتاحية لكل منها: http://www.4shared.com/rar/pmYpsxLx/31250864124.html أو من المرفقات بإسم : مرفق 2 الفصل(12): Oop بالتفصيل...الجزء الثاني - B3dak Hbebe - 23-09-12 التعدد [ [FONT=&]Polymorphism[/FONT] ]
من أجمل ما قرأت عن التعدد أو الـ [FONT=&]Polymorphism[/FONT] كان ذلك في كتاب ( Visual Basic 2008 ) لكاتبه Rod Stephens كان الآتي بالنص :Roughly speaking, polymorphism means treating one object as another. In OOP terms, it means that you can treat an object of one class as if it were from a parent class. فعلا هكذا ، أثناء تعرضك للتعدد أو الـ [FONT=&]Polymorphism[/FONT] فأنت يمكنك معاملة الكائن كما لو كان كائن آخر .. على سبيل المثال فلنفترض افتراضاتنا السابقة وهي أنه لدينا الفئة المسماة [FONT=&]Employee[/FONT] وكذلك الفئة [FONT=&]Customer[/FONT] وهما مشتقان من الفئة الأب المسماة [FONT=&]Person[/FONT]. من هنا يمكنك معاملة الكائنات المصاحبة للفئتين [FONT=&]Employee[/FONT] وكذلك [FONT=&]Customer[/FONT] كما لو انك تتعامل مع كائنات الفئة الأب [FONT=&]Person[/FONT] وذلك لأنهم بكل بساطة للفئة الأب وليس الابن كما يظهر لك. يعني هذا انك ظاهرياً تتعامل مع الفئات [FONT=&]Customer[/FONT] و [FONT=&]Employee[/FONT] ولكن تستخدم هاتين الفئتين كجسر من خلاله تتعامل في الباطن مع كائنات الفئة الأب [FONT=&]Person[/FONT]. يُمكنك الـ [FONT=&]Visual[/FONT][FONT=&]Basic .NET[/FONT] من تعيين أو تخصيص قيمة من فئة مشتقة إلى متغير في الفئة الأب. في المثال التالي يمكنك أن تضع كائني [FONT=&]Employee[/FONT] أو [FONT=&]Customer[/FONT] في متغير من الفئة الأب ... اتبع الكود ثم تابع رابط المشروع في الأسفل : كود : [align=left]Dim emp As New Employee 'Create an Employee. يمكنك تحميل المشروع من الرابط التالي :
http://www.4shared.com/rar/kbnuyugP/11250864124.html أو من المرفقات بإسم : مرفق 3 يمكنك الوصول للمعالم أو المكونات المُعرفة الخاصة بنوع المتغير الذي تستخدمه للإشارة إلى كائن آخر. هذا يعني أنك مثلاً لو لديك متغير من النوع [FONT=&]Person[/FONT] يشير إلى كائن من النوع [FONT=&]Employee[/FONT] فإنك فقط تستطيع الاستفادة من معالم الفئة [FONT=&]Person[/FONT] وليس لك الحق في الاستفادة مما تم إضافته على الفئة [FONT=&]Employee[/FONT] بعد الوراثة. اعادة التعريف[FONT=&]Overloading[/FONT] ماذا لو أنك قمت بتصميم فئة Class وأردت عمل إجراء فرعي Subroutine بالاسم [FONT=&]InsertPersonData[/FONT] ، وهذا الإجراء الفرعي يحتوي على الباراميترات أو المعاملات الآتية :
كود : [align=left]فقد قمنا في الإجراء السابق بجعل بقية الاختيارات من النوع [FONT=&]Optional[/FONT] ولكن للأسف وبكل أسف ستجد أن المعاملات من النوع [FONT=&]Optional[/FONT] يجب أن تحتوي على قيم مبدئية وهذا نصاً للاعتراض الذي يصدره الـ Visual Basic .NET بالنص الآتي : [FONT=&]Optional parameters must specify a default value[/FONT]
ولو طبقنا هذا الاعتراض في مثالنا الحالي فسنجد مثلا أننا قمنا بتعريف المتغير [FONT=&]Age[/FONT] على أنه متغير رقمي من النوع [FONT=&]Integer[/FONT] ونوعه اختياري [FONT=&]Optional[/FONT] وقيمته الافتراضية = 20 ، وهذا يعني أن المستخدم لهذا الإجراء لن يستطيع الاستفادة من هذا الإجراء لأنه لو لم يقوم بإدخال عمر الشخص فان البرنامج يقوم بشكل افتراضي بوضع القيمة 20 في حقل العمر في حين أن المستخدم للإجراء لا يعرف أو لم يتوفر لديه أية بيانات عن عمر الشخص. أعتذر لو استطردت كثيراً في وصف المشكلة ، ولكن هنا يأتي دور الـ Overloading ، فهل تعلم أن الـ Visual Basic .NET يعطيك إمكانية تكرار أو إنشاء أكثر من وسيلة Method بنفس الاسم ولكن بشرط اختلاف المعاملات. أي أنك من الممكن مثلاً أن تقوم بإنشاء الإجراء السابق المسمى [FONT=&]InsertPersonData[/FONT] أكثر من مرة وبنفس الاسم ولكن يختلف في المعاملات الممررة إليه. بالطبع أثناء استخدامك للغات الـ .NET لاحظت الآتي : إذا نظرت إلى ما يشير إليه السهم في الصورة السابقة ستجد الرمز الآتي ([FONT=&]1 of 12 [/FONT]) وهذا يعني بكل بساطة أن الإجراء أو الوسيلة المسماة [FONT=&]Input[/FONT] موجودة داخل الـ .NET Framework اثنتي عشرة مرة ولكن مع اختلاف المدخلات أو المعاملات وهذا تطبيق حي للـ Overloading.
تعال معي نضرب مثلاً آخر .. الفئة المسماة [FONT=&]Person[/FONT] يظهر فيها إجراءان كإجراءات مشيدة للفئة Constructor Subroutines بالاسم New. الإجراء المشيد الأول لا يأخذ أية معاملات بينما الإجراء المشيد الثاني يأخذ المعاملان المتغيران ( [FONT=&]FirstName[/FONT] , [FONT=&]LastName[/FONT] ) كقيم افتراضية أثناء أخذ نسخة Instance من الفئة. وسيكون شكل الفئة Person بعد كتابة الكود كما يلي : كود : [align=left]Public Class Personوإذا ذهبت للنموذج وقمت بأخذ نسخة من هذه الفئة سيظهر لديك الشكل التالي : وهنا تضح فائدة الـ Overloading فبدلاً من استخدام المعاملات الاختيارية Optional Parameters وكذلك حالات الشرط IF Conditions ، فنلجأ حينئذ لمثل هذه الطرق والتي تحل مشاكل كثيرة. وفيما يلي مثال صغير عن أخذ نسختين وإسنادهما للكائنات [FONT=&]Person_1[/FONT] وكذلك [FONT=&]Person_2[/FONT] كما يلي : كود : [align=left]Dim Person_1 As New Personيمكنك تحميل المثال من الرابط التالي :
http://www.4shared.com/rar/kbnuyugP/11250864124.html أو من المرفقات بإسم : مرفق 4 ولكن هل جاء بذهنك أخي القارئ ما هي ميكانيكية تحديد الإجراء ، يعني مثلاً أنه لدينا ثلاثة إجراءات بالاسم [FONT=&]New[/FONT] وبالطبع كما ذكرنا أن لكل منهما معاملاته الخاصة التي تختلف عن المعاملات الخاصة بنظائره ، فكيف أقوم بتحديد التعامل مع الأول أو الثاني أو الثالث ... الخ ؟. هنا يقوم الـ Visual Basic .NET بتحديد الإجراء حسب نوعية وعدد الإجراءات الممررة إليه وليس عليك أية التزامات تجاه هذه الجزئية.
** ملحوظة مهمة جدا ** عند استخدامك للدوال أو ما يسمى بالـ Functions ، فيكون نفس ما تمرسنا عليه في الإجراءات مع الـ Overloading هو نفسه مع الـ Functions ، إلا أنه يوجد جزية هامة يجب التنويه عنها. من البديهي أن يدور بذهن أحدكم فيما يخص الـ Functions أنه إذا تم تغيير نوع الدالة أو ما يسمى بالـ Return Type فهذا يحقق الـ Overloading ... !!! ، وهنا سأصدمك بلا شك وأقول لك لن يحدث هذا ، فتحقيق الـ Overloading مع الدوال لا يأتي بتغيير نوع الدالة فقط ، ولكن لابد تحقق شرط آخر وهو اختلاف المعاملات. انسخ الكود التالي في محرر Visual Basic .NET واقرأ نص الاعتراض بنفسك : كود : [align=left][b][FONT=Tahoma]
وكي لا أرهقك في القراءة من المحرر فنص الخطأ يفيد الآتي : " لا يمكن أن تتعدد الدالة cannot overloaded each other وذلك لاختلافهم فقط في النوع Return Type". أما إذا أردت تصحيح الأوضاع فإليك الكود الصحيح :
كود : [align=left]Function MySum(ByVal FirstNumber As Double, ByVal SecondNumber As Double) As Double** تم إضافة الدالة المسماة MySum إلى المثال OOP4 **
والان بحمد الله تم الانتهاء من الOOP بنوع من التفصيل المجمل ملاحظة:جميع الامثلة صممت ببرنامج ال VB2008.NET وملاحظة اخرى: يعدكم الاستاذ احمد نجم باصدار كتاب عن الOOP قريبا ان شاء الله بالتوفيق دمتم بود الفصل(12): Oop بالتفصيل...الجزء الثاني - abdoojh - 23-02-13 بارك الله فيكم اخواني على المجهودات الطيبة ولكن في الحقيقة لم افهم الكثير ربما لاني مبتدئ والدرس يعتبر لفئة متقدمة الفصل(12): Oop بالتفصيل...الجزء الثاني - خليل اسماعيل - 27-04-13 بارك الله فيك |