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

من موسوعة حسوب
< Refactoring
مراجعة 05:37، 20 يوليو 2018 بواسطة Nourtam (نقاش | مساهمات) (تعديل مصطلح تضمين الأصناف (inline classes))
اذهب إلى التنقل اذهب إلى البحث
The printable version is no longer supported and may have rendering errors. Please update your browser bookmarks and please use the default browser print function instead.

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

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

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

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

أسبابها

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

وما الحل؟

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

إليك المزيد

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

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

انظر أيضًا

مصادر