Refactoring/change value to reference
المشكلة
عند وجود العديد من المثيلات المتطابقة من صنفٍ واحد تحتاج إلى استبدالها بكائنٍ واحد.
الحل
تحويل الكائنات المتطابقة إلى كائن مرجعي واحد.
لم إعادة التصميم؟
في العديد من الأنظمة، يمكن تصنيف الكائنات علي إنها إمَّا قيم أو مراجع.
- المراجع: عندما يتوافق كائن واحد في العالم الحقيقي مع كائنٍ واحدٍ فقط في البرنامج. عادةً ما تكون المراجعُ كائنات مثل المستخدم/النظام/المنتج الخ.
- القيم: عندما يتوافق كائن واحد في العالم الحقيقي مع كائنات متعددة في البرنامج. ويمكن أن تكون هذه الكائنات التواريخ وأرقام الهواتف والعناوين والألوان وما شابه ذلك.
لا يكون اختيار المرجع مقابل القيمة دائمًا واضح المعالم. في بعض الأحيان يكون هناك قيمة بسيطة مع كمية صغيرة من البيانات التي لا تتغير. ثم يصبح من الضروري إضافة بيانات قابلة للتغيير وتمرير هذه التغييرات في كل مرة يُوصَل فيها إلى الكائن. في هذه الحالة يصبح من الضروري تحويلها إلى مراجع.
فوائد تطبيق الحل
- يحتوي الكائن على كافة المعلومات الحالية حول كيان معين. إذا تغير الكائن في أحد أجزاء البرنامج، يمكن الوصول إلى هذه التغييرات من الأجزاء الأخرى من البرنامج التي تستخدم هذا الكائن.
مساوئ تطبيق الحل
- من الصعب جدًا تنفيذ المراجع.
آلية الحل
- استخدام استبدال المُنشِئ بتابع التصميم مع الصنف الذي تُنشأ منه المراجع.
- تحديد الكائن الذي سيكون مسؤولًا عن توفير الوصول إلى المراجع. بدلًا من إنشاء كائن جديد، عندما تحتاج واحدًا تصبح بحاجة الآن للحصول عليه من كائن تخزين أو حقل قاموس ثابت.
- تحديد ما إذا كانت المراجع ستُنشَأ مسبقًا أو بشكل ديناميكي حسب الضرورة. إذا أُنشئت الكائنات مسبقًا، يجب التأكد من تحميلها قبل الاستخدام.
- تغيير تابع التصميم بحيث يُعيد مرجعًا. إذا أُنشئت الكائنات مسبقًا، حدد كيفية التعامل مع الأخطاء عند طلب كائن غير موجود. قد تحتاج أيضا إلى استخدام تابع إعادة التسمية للإبلاغ بأن التابع يُعيد الكائنات الموجودة فقط.
انظر أيضًا
- استبدال المُنشِئ بتابع التصميم.
- تابع إعادة التسمية.
- العملية المُعاكسة تبديل الكائنات إلى قيم البيانات.