الفرق بين المراجعتين لصفحة: «Refactoring/message chains»
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE:سلاسل الرسائل (Message Chains)}}</noinclude> == توصيف المشكلة == وجود العديد من الاستدعاءات ال...' |
طلا ملخص تعديل |
||
سطر 18: | سطر 18: | ||
== انظر أيضًا == | == انظر أيضًا == | ||
* [[Refactoring/hide delegate|إخفاء التفويض (hide delegate)]] | * [[Refactoring/hide delegate|إخفاء التفويض (hide delegate)]] | ||
* [[Refactoring/extract method|استخراج | * [[Refactoring/extract method|استخراج التابع (extract method)]] | ||
* [[refactoring/move method|نقل التابع (move method)]] | * [[refactoring/move method|نقل التابع (move method)]] | ||
* [[Refactoring/middle man|مشكلة الوسيط (middle man)]] | * [[Refactoring/middle man|مشكلة الوسيط (middle man)]] |
مراجعة 14:15، 30 سبتمبر 2018
توصيف المشكلة
وجود العديد من الاستدعاءات المتسلسلة في الشيفرة، مثل: $a->b()->c()->d()
.
أسبابها
تحدث المشكلة عند طلب العميل (client request) كائنًا (object) آخر والذي بدوره يطلب كائنًا آخر ثالثًا وهكذا، مما يعني اعتماد العميل على التنقّل (navigation) في بنية الأصناف (class structure)، وبالتالي فإنّ أيّ تعديلٍ في تلك العلاقات سيتطلَّبُ إجراء التعديلات أيضًا على العميل بحدِّ ذاته.
وما الحل؟
- إخفاء التفويض (hide delegate) لحذف الاستدعاءات المُتسلسلة.
- قد يساعد -ببعض الحالات- التفكيرُ بسبب الوصول إلى آخر كائنٍ (object) مستدعى، وعندها يمكن اللجوء إلى استخراج تابعٍ (extract method) يقوم بالمهمة ذاتها، أو الاعتماد على نقل التابع (move method) لجعل المهمّة في بداية سلسلة الاستدعاءات بدلًا من نهايتها.
إليك المزيد
سيخفِّف حلُّ المشكلة من الاعتمادية (dependency) ما بين أصناف (classes) السلسلة الواحدة، كما وسيقلِّلُ أيضًا من حجم الشيفرة المُستخدَمة.
تجاهل المشكلة
قد يُسبِّبُ الإخفاء المفرط للتفويض (aggressive delegate hiding) الحصولَ على شيفرةٍ يصعُب فيها تحديد مكان تنفيذ العمليّات الفعليّة (functionality)، فكن يقظًا لتجنُّب الوقوع بمشكلةٍ أخرى من مشاكل الشيفرات وهي مشكلة الوسيط (middle man).
انظر أيضًا
- إخفاء التفويض (hide delegate)
- استخراج التابع (extract method)
- نقل التابع (move method)
- مشكلة الوسيط (middle man)