تغيير الأصناف المتعدِّدة (Shotgun Surgery)

من موسوعة حسوب
< Refactoring
مراجعة 14:05، 26 فبراير 2019 بواسطة جميل-بيلوني (نقاش | مساهمات) (مراجعة وتدقيق.)
(فرق) → مراجعة أقدم | المراجعة الحالية (فرق) | مراجعة أحدث ← (فرق)
اذهب إلى التنقل اذهب إلى البحث

ملاحظة قبل البدء

إنّ مشكلة تغيير الأصناف المتعدِّدة هي المشكلة المعاكسة تمامًا لمشكلة التغيير المتشعِّب (Divergent Change)، إذ إنّ التغيير المتشعِّب هو مجموع التغييرات الكثيرة التي تُجرَى في صنفٍ (class) واحدٍ، أما تغيير الأصناف المتعدِّدة فهو تغييرٌ واحدٌ يُجرَى في العديد من الأصناف.

توصيف المشكلة

يتطلَّبُ أيُّ تعديلٍ تقوم به إجراءَ تغييراتٍ طفيفةٍ بأصناف (classes) متفرِّقة.

أسبابها

توزيع مهمةٍ واحدةٍ على الكثير من الأصناف، ويحدث هذا نتيجةً للتطبيق المفرط للتغيير المُتشعِّب (Divergent Change).

وما الحل؟

نقل سلوك (behaviour) الأصناف إلى صنفٍ (class) واحدٍ عبر نقل التوابع (move methods) ونقل الحقول (move fields) إلى الصنف المناسب أو إنشاء صنفٍ جديدٍ عند عدم وجوده، فإن أصبحت الأصناف الأصليّة فارغةً بعد نقل الشيفرة منها إلى صنفٍ واحدٍ فمن الأفضل التُخلُّص منها عبر تضمين الأصناف (inline classes).

إليك المزيد

ستحصل بعلاجك المشكلة على:

  • تنظيمٍ أفضل للشيفرة.
  • تقليل الشيفرات المُتكرِّرة (duplications).
  • صيانةٍ (maintenance) أسهل.

انظر أيضًا

مصادر